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INTRODUCTION 



This is one of two boolcs that replace An Introduction to Microcomputers: Volume 2 — Some Real Microprocessors. That 
volume went through several printings and in 1 978 was printed loose-leaf. Six bimonthly updates to the loose-leaf ver- 
sion were published in 1979 and early 1980 to provide information on newly introduced microcomputer devices. The 
loose-leaf version proved, however, to be quite unpopular with bookstores because of packaging and handling con- 
siderations. It also became more and more difficult to maintain a timely flow. of the bimonthly updates. For these 
reasons. Volume 2 is being replaced by two bound paperback books: the Osborne 4 & 8-Bit Microprocessor Handbook 
and the Osborne 1 6-Bit Microprocessor Handbook. Together these handbooks include all of the information that was 
contained in Volume 2 and the six updates. All known errors have been corrected and new data sheets have been 
added to the two handbooks. We have divided Volume 2 into two separate handbooks because the single-volume ver- 
sion would be over 1800 pages in length and rather difficult to bind. In addition, the devices lend themselves to this 
grouping since the 16-bit microprocessors are generally much more powerful than the four- and eight-bit 
microprocessors, and thus are directed toward different applications. 

Volume 2 was part of a four-volume Introduction to Microcomputers series: 

Volume — The Beginner's Book was written for readers who know nothing about computers. 
Volume 1 — Basic Concepts provides a detailed explanation of microprocessor concepts including number 
systems, addressing modes, typical instruction sets, input/output techniques, and so on. The device descrip- 
tions in the 4 & 8-Bit Microprocessor Handbook and the 16-Bit Microprocessor Handbook assume that you 
have a working knowledge of the general concepts presented in Volume 1. and we will occasionally make 
references to material presented in Volume 1. 

Volume 2 — Some Real Microprocessors, which is being replaced by these handbooks. 
• Volume 3 — Some Real Support Devices, which describes general support devices that may be used with 
any microprocessor. Some dedicated support devices are the 4 & 8-Bit Microprocessor Handbook and the 
1 6-Bit Microprocessor Handbook. We define a "dedicated" support device as one best used with its parent 
microprocessor. We define a "general" support device as one that can be used with any microprocessor. We 
will occasionally make reference in this book to some of the general support devices in Volume 3. When 
designing a system based on one of the microprocessors described in this handbook, you should not auto- 
matically assume that the dedicated support devices described in this book are the only ones or the best 
ones to use with a particular microprocessor: you should always check the functionally equivalent parts de- 
scribed in Volume 3. 

In addition to this Introduction to Microcomputers series, we have begun publishing other individual handbooks. The 
first two handbooks of this series are: The 8089 110 Processor Handbook, which includes the 8289 bus arbiter, and the 
CRT Controller Handbook, which describes five LSI CRT controller devices. This individual handbook approach will be 
used in the future to maintain a convenient flow of detailed, objective information on new microprocessors and related 
support devices. 



SIGNAL CONVENTIONS 

Signals may be active high, active low or active in two states. An active high signal is one which, in the high 
state, causes events to occur, while in the low state has no significance. A signal that is active low causes 
events to occur when in the low state, but has no significance in the high state. A signal that has two active 
states will cause two different types of events to occur, depending upon whether the signal is high or low; this 
signal has no inactive state. Within this book a signal that is active low has a bar placed over the signal name. 
For example, WR identifies a "write strobe" signal which is pulsed low when data is ready for external logic to 
receive. A signal that is active high or has two active states has no bar over the signal name. 



TIMING DIAGRAM CONVENTIONS 

Timing diagrams play an important part in the description of any microprocessor or support device. Timing 
diagrams are therefore used extensively in this book. All timing diagrams observe the following conventions: 



1) A low signal level is equivalent to no voltage. A high signal level is equivalent to voltage present: 

/— — — — — ^ Voltage present 



2) A single signal nnaking a low-to-high transition like this: 

low ' 

3) A single signal making a high-to-low transition is illustrated like this: 

high > 



high 



low 



4) When using two or nnore parallel signals exist, the notation: 

signals change 



fc 



States that one or more of the parallel signals change level, but the transition (high-to low or low-to-high) is 
unspecified). 

5) A three-state single signal is shown floating thus: 



6) A three-state bus containing two or more signals is shown floating thus: 



y ^ 

•J Ri.c v. 



Bus 
floating 

7) When one signal condition triggers other signal changes, an arrow indicates the relationship as follows: 

Condition 
here 



Causes 

change 

here 



Thus a signal making a low-to-high transition would be illustrated triggering another signal making a high-to-low 
transition as follows: 




A signal making a high-to-low transition triggering a bus change of state would be illustrated as follows: 




8) When two or more conditions must exist in order to trigger another logic event, the following illustration is used: 



These 
conditions 



cause 

change 

here 

Thus a low-to-high transition of one signal occurring while another signal is low would be illustrated triggering a 
third event as follows: 



\ 



9) When a single triggering condition causes two or more events to occur, the following illustration is used: 



This 
condition 



causes 

these 

changes 



Thus a low-to-high transition of one signal triggering changes in two other signal levels would be illustrated as 
follows: 




10) All signal level changes are shown as square waves. Thus rise and fall times are ignored. These times are given in 
the data sheets which appear at the end of every chapter. 



INSTRUCTION SET CONVENTIONS 

Every microcomputer instruction set is described with two tables. One table identifies the operations which 
occur when the instruction set is executed, while the second table defines object codes and instruction times. 

Because of the wide differences that exist between one instruction set and another, we have elected not to 
use a single set of codes and symbols to describe the operations for all instructions in all instruction sets. We 
believe any type of universal convention is like to confuse rather than clarify; therefore each instruction set 
table is preceded by a list of symbols as used within the table alone. 

A short benchmark program is given to illustrate each instruction set. Some comments regarding benchmark 
programs in general are, however, in order. We are not attempting to highlight strengths or weaknesses of 
different devices, nor does this book make any attempt to comparative analyses, since the criteria which make 
one microcomputer better than another are simply too dependent on the application. 



Consider an application which requires relatively high speed processing. The only important cri- COMPARATIVE 
terion will be program execution speed, which may limit the choice to just one of the microcom- ANALYSIS 
puters we are describing. 

Execution speeds of all of the microcomputers may, on the other hand, be quite adequate for a second application; in 
this case, price may be the only overriding factor. In a third application, a manufacturer may have already invested in a 
great deal of engineering development expense, using one particular microcomputer that was available in quantity ear- 
lier than any others; the advantages or disadvantages of using a different microcomputer, based on minor cost of per- 
formance advantages, will likely be overwhelmed by the extra expense and time delays involved with switching in 
midstream. 



BENCHMARK 
PROGRAMS 



And what about benchmark programs? 

There have been a number of benchmark programs in the literature, purporting to show the 

strengths or weaknesses of one microcomputer versus another; individual manufacturers 

have added to the confusion by putting out their own competing benchmarks, aimed at showing their product to 

be superior to an immediate rival. 

Benchmark programs are misleading, irrelevant and worthless for these reasons: 

1) In a majority of microcomputer applications, program execution speed, and minor variations in program 
length, are simply overwhelmed by pricing considerations. 

2) Even assuming that for some specific application, program length and execution speed are important, trivial 
changes in the benchmark program definition can profoundly alter the results that are obtained. This is one 
point we will demonstrate in this book, while describing individual instruction sets. 

3) Benchmark programs are invariable written by the smartest programmers in an organization, and they take 
an enormous amount of time to ensure programming accuracy and excellence. This is not the level at which 
any user should anticipate "run of the mill" programmers working; indeed, a far more realistic evaluation of 
a microcomputer's instruction set could be generated by giving an average programmer too little time in 
which to implement an incompletely defined benchmark. This will more closely approximate the working 
conditions under which real products are developed. Of course, defining the "average programmer," "too 
little time" and an "incomplete specification" are all sufficiently subjective that they defy resolution. 



We will demonstrate the capriciousness of benchmark programs via the following benchmark program: 

Raw data has been input to a general purpose input buffer, beginning at lOBUF. This raw data is to be moved to 
a permanent table, which may be partially filled; the raw data is to be stored in the data table starting with the 
first unfilled byte. The benchmark may be illustrated as follows: 



lOBUF 




TABLE 



HOW THIS BOOK HAS BEEN PRINTED 

Notice that text in this book has been printed in boldface type and lightface type. This has been done to help you 
skip those parts of the book that cover subject matter with which you are familiar. You can be sure that 
lightface type only expands on information presented in the previous boldface type. Therefore, only read boldface 
type until you reach a subject about which you want to know more, at which point start reading the lightface type. 



Chapter 1 

THE NATIONAL SEMICONDUCTOR 

PACE AND INS8900 

PACE was developied by National Semiconductor as a single-chip Implementation of its multi-chip IMP-16. 
Since it was the first 16-bit, single-chip microprocessor, PACE is the first 16-bit microprocessor described in 
this book. 

As might be expected of an early entry product. PACE had a number of problems — both in design and fabrication 
technology — which limited its acceptance. Therefore the INS8900 was recently introduced by National Semiconduc- 
tor. The INSBSOO is a redesigned, NMOS PACE, with internal logic problems resolved. 

In this chapter we will describe both PACE and the INS8900. Specifically, we will identify the problems faced by a 
PACE user, which have been eliminated in the iNS8900. 

PACE and the INS8900 are 16-bit microprocessors because they handle data in 16-bit units. In many ways, however, 
the internal architecture of PACE and the INS8900 have an 8-bit orientation; this is something you should keep in mind 
while reading this chapter, because it does result in PACE and the INS8900 having program execution speeds that are 
comparable to, rather than being significantly faster than, the 8-bit microprocessors we have described in earlier chap- 
ters. 

The only current manufacturer for PACE and the INS8900 is: 

NATIONAL SEMICONDUCTOR, INC. 

2900 Semiconductor Drive 

Santa Clara, CA 95050 

There are agreements between Rockwell International and National Semiconductor and between Signetics and 
National Semiconductor to exchange microcomputer technical information and to produce each other's products. At 
the present time, neither Signetics nor Rockwell International has elected to second source PACE or the iNS8900, and it 
is extremely unlikely that they will since both PACE and the INS8900 are products with limited futures. The amount of 
support that National Semiconductor provides is rapidly declining as newer, more powerful 16-bit microprocessors 
enter the marketplace. 

As shown in Figure 1-1, a typical PACE microcomputer will consist of a mixture of special-purpose PACE support 
devices and standard devices. The PACE microcomputer devices described in this chapter consist of: 

. The PACE CPU 

• The System Timing Element (STE), which generates clock signals for PACE and the system. 

• The Bidirectional Transceiver Element (BTE), which converts the MOS-level PACE signals to TTL-levei signals 
for other devices. The BTE Is 8 bits wide. 

The 1NS8900 needs a clock generator; a 2 MHz crystal and a 74C04 inverter are recommended. Otherwise, there are no 
special INS8900 support devices; in fact, you can easily use any NMOS support devices described in Volume 3 
with the INSSSOO. Specifically, the STE and BTE devices cannot be used with the INS8900, because they provide 
MOS-to-TTL signal level conversions for PACE 

PACE requires +5V, -I-8V and -12\/ power supplies. The +8V is a substrate voltage require- 
ment of the CPU and can be derived from the +5V power using a few discrete components 
Therefore, a system can be implemented using only two primary power supplies: +5V and 
-12V. The INS8900 also uses three power supplies: -t-12V, -f5V and -8V. 



PACE/INS8900 
POWER SUPPLY 



EXECUTION 
SPEED 



The INS8900 uses a 500 nanosecond clock to provide typical instruction execution times in the range of 8 to 20 
microseconds. PACE (IPC-16A/520D) uses a 750 nanosecond clock to provide typical instruction execution times in 
the range of 12 to 30 microseconds. 



M 



Before making direct comparisons of these instruction execution times with those of other devices, however, note 
carefully that because of the 16-bit architecture of PACE and the INS8900, it may tal<e many instructions on another 
microcomputer to perform the same operations as a single INS8900/PACE instruction. ^^__^___i^^ 

MOS level signals are input and output by PACE. TTL level signals are input and output by the PACE/INS8900 
INS8900. LOGIC LEVEL 



SYSTEM TIMING 
ELEMENT (STE) 



P-channel silicon gate, MOS/LSI technology is used with PACE. N-channel MOS technology is 
used by the INS8900. 

PACE AND INS8900 MICROCOMPUTER SYSTEM OVERVIEWS 

Figure 1-1 conceptually illustrates a PACE system. Figure 1-2 conceptually illustrates an INS8900 system. 
As with any mini- or microcomputer system, the CPU outputs data, address, and control signals. In the case of 
PACE and the INS8900, the data and address signals use the same bus lines; therefore, they are said to be 
multiplexed. 

Timing signals needed by PACE are generated by the System Timing Element (STE). 
PACE signals are all MOS level; the STE therefore generates two sets of timing signals; 
one set are MOS level for PACE, the other set are TTL level for external logic. 

Since PACE signals are MOS level. Bidirectional Transceiver Elements (BTEs) must be 
present to translate outgoing signals from MOS to TTL levels, and to translate incoming 
signals from TTL to MOS levels. BTEs are quite indiscriminating in the signals they translate; 
in either direction, any signal arriving at an input pin is faithfully reproduced at the corres- 
ponding output pin. Control signal options allow a BTE to operate bidirectionally, to drive output signals only, or to 
place both the MOS and TTL outputs in a high-impedance mode. Since the BTE is 8 bits wide, two BTEs operating 
bidirectionally provide buffering for the 16-bit Address/Data Bus. A third BTE, operating in the drive-only mode, pro- 
vides buffering for the PACE control signals (NADS, ODS, IDS, and Flags). 

A complete TTL level bus is created by combining BTE outputs with the TTL level timing 
signals output by the STE. Remember, though, that the 16 address/data lines are multiplexed. 



BIDIRECTIONAL 
TRANSCEIVER 
ELEMENT (BTE) 



TTL LEVEL 
PACE BUS 



External logic that can demultiplex these lines and that can respond to the PACE timing and con- 
trol signal logic can connect directly to the TTL level address/data lines. For example, National Semiconductor provides 
ROM and RAM devices with on-chip address latches; these devices can interface directly to the TTL level bus. 



If memory devices or I/O ports are used that cannot demultiplex the address/data lines, you must ADDRESS 
provide separate logic to perform this function. No special PACE family devices are available for LATCHES 
this purpose; however, standard logic devices can be used. For example, two hex flip-flop devices AND 
and a quad flip-flop device would provide a latched 1 6-bit Address Bus. Two 821 2 I/O ports could DECODERS 
also be used to latch the 16 bits of address information. The PACE Address Data Strobe (NADS) ^— ^— — — 
signal can be used as the CLK input to the flip-flops or as the STB input to the 8212s. The PACE Address Data Strobe 
(NADS) signal can be used as the CLK input to the flip-flops. In many systems this is the most effective approach since 
a latched Address Bus allows you to use simpler address decoding techniques to generate memory chip enable and I/O 
port select signals. 

Figure 1-2 illustrates an INS8900 microcomputer system. Logic is quite elementary — and equivalent to that 
which you would expect with any other microcomputer Control Bus, Data Bus, and Address Bus lines are buffered 
using 1NS8208 bidirectional buffers. These are National Semiconductor standard catalog devices, recommended by 
National Semiconductor and illustrated in their literature; however, any other buffer would do equally well. The 
Data/Address Bus is shown being demultiplexed by 8212s to create separate Data and Address Busses. This again is 
straightforward logic. 
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Figure 1-1. A National Semiconductor PACE Microcomputer System 



1-3 



n 



SENSE LINES IN 



INS8900 



I 



74C04 
INVERTER 



ThP 



i> 



INS8208 



C:^ 



IL 



TWO 
INS8208S 



C 



Li> 



ii 



TWO 
INS8212S 



A 



CONTROL BUS 



DATA BUS 



7\ 



A 



LATCHED ADDRESS BUS 



MinnanHai 



ROM 



RAM 



PERIPHERAL 



Figure 1-2. A National Semiconductor INS8900 Microcomputer System 

INS8900 PROGRAMMABLE REGISTERS 

The INS8900 (and PACE) has four 16-bit Accumulators and a 16-bit Program Counter; these registers may be il- 
lustrated as follows: 



ACO 


Primary Accumulator 


AC1 


Secondary Accumulator 


AC2 


Secondary Accumulators 


AG3 


and Index Registers 


PC 


Program Counter 



Accumulator ACO may be likened to a primary Accumulator as described for our hypothetical microcomputer in 
Volume 1. 

Accumulator AC1 is a secondary Accumulator. 

Accumulators AC2 and ACS are equivalent to a combination of secondary Accumulators and Index registers. 

Recall fronn Volume 1, Chapter 6 that an Index register differs from a Data Counter in that the Index register contents 
are added to a displacement (which is provided by a memory reference instruction) in order to determine the effective 
memory address. 

The Program Counter serves the same function in an INS8900 system as it does in our hypothetical microcom- 
puter described in Volume 1. 

Figure 1 -3 illustrates that part of our general microcomputer system logic which has been implemented in the 
INS8900 microprocessor. 
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Figure 1-3. Logic of the INS8900 Microprocessor 



INS8900 STACK 

A Stack is provided on the iNS8900 (and PACE) chip. The Stack is 1 6 bits wide and 1 words deep. The Stack is 
not a cascade stack, as described in Volume 1 , Chapter 6; rather, chip logic maintains its own Stack Pointer to identify 
the next free Stack word. The Stack Pointer is automatically incremented and decremented in response to Push and 
Pull operations. Stack Push and Pull operations are initiated by CPU logic during execution of Jump-to-Subroutine 
(JSR) and Return-from-Subroutine (RTS) instructions, and during interrupt processing, to automatically save and 
restore the Program Counter. 

In addition, the Stack can be used for temporary storage of data or status information. There are instructions 
which allow you to transfer words between the Stack and any Accumulator, or the Status and Control Flag register. 
This capability can significantly reduce the number of memory accesses required (thus increasing system speed) and 
can also reduce read/write memory requirements since intermediate values can be stored on the Stack. 

Whenever the Stack becomes completely filled or emptied, an Interrupt Request is 
generated on the INS8900 chip. If you have enabled Stack Interrupts, program execution will 
be suspended, allowing you to deal with the situation. A Stack Full condition will indicate that 
it is time to dump data accumulated on the Stack out to read/write memory. 



INS8900 AND 
PACE STACK 
INTERRUPTS 
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INS8900 AND PACE ADDRESSING MODES 

Most INS8900 (and PACE) memory reference instructions use either direct or direct, indexed addressing. A few 
instructions also offer indirect addressing and pre-indexed, indirect addressing. Refer to Volume 1 , Chapter 6 for a 
description of these addressing nnodes. 

All memory reference instructions have the following object code format: 



15 14 13 12 1110 9 8 7 6 5 4 3 2 1 - 

I I I I I I IxIrI I I I I I I I I 




Bit No. 



Address displacement 
Addressing mode selection 

00 = Base Page address 

01 = Program relative address 

10 = Indexed (AC2-relative) 

1 1 = Indexed (AC3-relatlve) 

Instruction operation code 



The 2-bit XR field lets you specify with each instruction the type of direct addressing you want used: base page, pro- 
gram relative or indexed (AC2- or AC 3- re la five). Since the address displacement is an 8-bit field in the instruction word, 
direct addresses are paged and each page consists of 256 words. Indexed and paged addressing variations have been 
described in Volume 1, Chapter 6. 

In addition, the INS8900 (and PACE) offers a variation of base page addressing, which is 
not described in Volume 1 , Chapter 6. There is a control input signal (BPS) which allows 
the base page to be split between the top and bottom 128 words of memory, as follows: 



INS8900 AND 
PACE SPLIT 
BASE PAGE 



Normal Base Page MEMORY Split Base Page 



Displacement 
through 



ment =00 J 



0000 



OOFF 



Base Page 



I 0000 
007F 



Base Page 






Displacement = 00 through 7F 



Displacement = 80 through FF 
Frequently these addresses are 
reserved for external devices 



BPS high splits the base page; BPS low keeps the base page as the bottom 256 words of 
memory. 

Depending on how an 1NS8900 system has been configured, the base page may be permanently defined as split or as 
normal: or the base page may be varied between the two options under program control. There are a number of output 
control flags (which are described next) that may be set or reset under program control. If one of these flags is con- 
nected to the base page select pin, then setting or resetting this flag determines which base page option will be in 
effect: 
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Splitting the base page between the top and bottonn of memory is useful in an INS8900 microcomputer system 
because it simplifies external device addressing. If we reserve all memory addresses in the range FF8O16 " FFFFig for 
external devices, then external logic merely has to AND the top nine bits of an address and thus determine if an exter- 
nal device (rather than a memory location) is being addressed: 



15 14 13 12 n 10 9 8 7 6 5 4 3 2 







i'i'mihhiihi'ixixixix|xixi;i 




■ Bit No. 



8 or higher 



If these nine bits are all 1, then an 
external device is addressed 



Splitting the base page also makes it easy to implement half of the base page in ROM, leaving the other half in RAM 



To a programmer, this scheme provides an easy way of generating 1 28 external device 
addresses. If the split base page option is in effect, then base page, direct addressing can be 
interpreted as external device addressing, so long as the high-order bit of the displacement is 
1; 



INS8900/PACE 
SPLIT BASE 
PAGE TO 
ADDRESS I/O 




15 14 13 12 11 10 



I I I I I I IxIrI I II I I I I I 



I 



I 



Memory Reference instruction code 
Displacement 

Bit No. 



-Becomes I/O instruction if there is a 1 here and 
split base page is being used to address I/O 



> 00 sp>ecifies 
Base Page addressing 



The base page and program relative options do not apply when the displacement is part of a 
direct indexed address. When indexed addressing is specified, the INS8900 adds the con- 
tents of the displacement, as a signed binary number, to the contents of the identified 
Index register (AC2 or ACS). The sum becomes the effective address. Here are some ex- 
amples; 



INS8900/PACE 
DIRECT INDEXED 
ADDRESSING 



iex Register 


Displacement 






Contents 


Value 




Effective 


213A,^ 


4C,e 




213A 

_.,„.-.^' 004C 

2186 




Propagated Sign 


Bit 


213A 


213A,, 


C4,e 




20FE 



Observe that the high-order bit of the displacement, being a sign bit, is propagated through the missing high-order dis- 
placement byte. 

Instructions that allow indirect addressing simply superimpose indirect addressing logic on the preceding direct 
address generation logic. For example, if indirect addressing without indexing is specified, then a base page or pro- 
gram relative direct, address will be computed in the normal way, but the effective address is contained in the memory 
location identified by the direct address. 
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This illustration shows base page, indirect addressing; arbitrary nrtemory addresses are used to make the illustration 
easier to understand: 



lUlamrvk* 


.^ 


0000 
0001 

0043 
0044 
0O45 
0046 
0047 

2178 
2179 
217A 
217B 
217C 








Address 
















_.,—._ - _ 


21 7A 


DISP-45,, 
























r-rw 








Memory 




Address 





This word addressed indirectly 



This illustration shows program relative, indirect addressing, again using arbitrary memory addresses: 

MEMORY 



MEMORY 



Base Qage word addressed directly 



DISP=9D..(=-63J 



i« ' — 1«' 



Program Counter 



Effective 
Memory 
Address 




2178 
2179 
217A 
2178 



21 7A 



Program relative, direct addressed word 



This word addressed indirectly 



1-8 



If indirect addressing with indexing is specified, then a direct address is first computed by adding the displacement, as 
a signed binary number, to the contents of the specified Index register; the direct indexed address thus computed pro- 
vides the memory location where the indirect address will be found. This is illustrated as follows: 







MEMORY 


B a 






OFDD 
OFDE 


Address 










21 7A 




OFEO 
extended sign bit 

2178 
2179 


DISP = 9D,g 




1042 + FF9D = OFDF 












Effective 




217B 
217C 


Memory 




Address 





Direct, indexed addressed word 



This word addressed indirectly 



INS8900 AND PACE STATUS AND CONTROL FLAGS 

The INS8900 has a 16-bit Status and Control Flag register. This register is on the CPU chip and is illustrated as 
follows: 



„,„ 

EXIT 
INTO 


F14 


F13 


F12 


F11 


BYTE 


INT 

EN 


LINK 


CRY 


OVF 


IE5 


IE4 


IE3 


IE2 IE1 "1" 




F14 F13 F12 F11 



Fourteen of the 16 register bits are used. Three of the 14 bits are status flags as we define a status flag. These 
three flags are: 

Overflow (OVF), which is a typical Overflow status. 

Carry (CRY), which is set and reset by arithmetic operations, as described for a typical Carry status. 
Link (LINK), which is set and reset by Shift and Rotate instructions, as described for the hypothetical microcom- 

puter's Carry status in Volume 1, Chapter 7. 

The separation of Carry into two statuses, one for shift and rotate operations, and the other for arithmetic 
operations, is a fairly common minicomputer feature: the advantage of separating these two statuses is that the 
results of arithmetic operations can be preserved across subsequent Shift and Rotate instructions. 

BYTE causes data to be accessed in 8-bit lengths when this status is set to 1 , or in 1 6-bit lengths when this status is 
set to 0. 

Five bits (IE1 through IE5) are reserved for interrupt processing. These five bits selectively enable and disable five 
interrupt lines. One of these lines (IE1 ) is reserved for the Stack Overflow interrupt, the other four lines are available for 
external device interrupt requests. There is also a master interrupt enable and disable bit (INT EN). 

Bits F1 1, F12, F13 and F14 are control flags which are output directly to INS8900 and PACE device pins; they can 
be used in any way to control external devices. One use, to select normal or split base page addressing, has already 
been described. 

Only the three status flags OVF, CRY and LINK are automatically set or reset in the course of instruction execu- 
tion. The remaining 1 1 bits of the Status and Control Flags register are set and reset by instructions or instruction se- 
quences that read data into, or write data out of, the Status and Control Flags register. 
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INS8900 AND PACE CPU PINS AND SIGNALS 

Pins and signals are illustrated in Figure 1-4 for the INS8900 and PACE devices. There 
are some small differences between the two sets of pin outs. These differences are 
shaded in Figure 1-4 . Within the shaded areas, the INS8900 signal is shown closest to the ar- 
row. The PACE signal is shown in brackets further out. Here is a sunnmary of pins that differ: 



INS8900 
AND PACE 
SIGNAL 
DIFFERENCES 



Pin 



INS8900 



PACE 



Number 


Signal 


Signal 


20 


GND 


Vss (+5V) 


23 


Vbb (-8V) 


Vbb (+8V) 


24 


CLKX 


NCLK 


25 


Vcc (+5V) 


CLK 


29 


Vdd (+12V) 


VgG (-12V 



The pin out differences between PACE and the INS8900 are not surprising. Since PACE uses P-channel MOS tech- 
nology, while the INS8900 uses N-channel MOS technology, we would expect power supply differences. Also, the 
INS8900, being a newer product, requires just one clock signal input (CLKX), compared to the two required by PACE 
(CLK and NCLK). 

Let us examine the pins and signals in detail. 




PIN NAME 

CLKX (CLK, NCLK) 
•D00-D15 
•IDS 
•ODS 
•NADS 
•EXTEND 
•NINIT 
•NHALT 
•CONTIN 
•BPS 

•JC13-JC15 
•F11 -F14 
♦NIR2 - NIR5 

Vbb- VqG' VsS' Vcc 

•JC13-JC15 

•These signals connect 



DESCRIPTION 

Clock Lines 
Data /Address Lines 
Input Data Strobe 
Output Data Strobe 
Address Data Strobe 
Clock Delay 
CPU Initialize 
Stop CPU 

Continue Jump Condition 
Base Page Select 
Control Flags 
Control Flags 
Interrupt Requests 
Power and Ground Lines 
Jump Conditions 
to the System Bus. 



TYPE 

Input 

Tristate, Bidirectional 

Output 

Output 

Output 

Input 

Input 

Bidirectional 

Bidirectk>nal 

Input 

Output 

Output 

Input 

Input 

Input 



Figure 1-4. INS8900 and PACE CPU Signals and Pin Assignments 
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There are 16 data and address lines (DO - D15), which are multiplexed for data input, data output and address 
output. Two control lines, ODS and NADS, identify output on the data and address lines as either data (ODS) or 
addresses (NADS). A further control line, IDS, is used to strobe data input. 

The EXTEND control input is used by slow memories or external devices to lengthen an instruction's execution 
time by increasing the duration of a data input/output cycle: this extends the time available for nnennories or external 
devices to capture data output, or to present input data. 

The NINIT input control initializes PACE; the Program Counter is set toO. The Stack Pointer, the Stack and the Status 
and Control Flags register are cleared. 

BPS has already been described; it is used to select either normal or split base page, for base page direct ad- 
dressing. 

NHALT is a bidirectional control signal used by interrupt and halt logic. As an input. NHALT can induce a Halt state, 
or in conjunction with CONTIN, it can generate a level (highest priority) interrupt request. When the CPU executes a 
Halt instruction, NHALT is output high to identify the Halt state. The various uses of NHALT and its interaction v\/ith 
CONTIN are described in detail later in this chapter. 

The CONTIN signal is used to terminate a Halt condition and is also used as an output interrupt acknowledge 
signal. When CONTIN is properly sequenced with the NHALT signal, it initiates a high priority interrupt, as we men- 
tioned in the preceding paragraph. CONTIN can also be used as a Jump condition input in the same way as JC13, 14 

and 15, which are described next. 

JC1 3, 14 and 15 provide an interesting capability found in very few microcomputers discussed in this book; the con- 
dition of these three inputs can be tested by a Branch-on-Condition (BOO instruction, thus allowing external con- 
trol signals to directly manipulate PACE program instruction sequences. 

F11, 12, 13 and 14 are the outputs for the corresponding flag bits in the Status and Control Flags register. 

NIR2, 3, 4 and 5 are the external interrupt request lines. Interrupt priority arbitration logic is included on the 
INS8900 (and PACE) chip. NIR2 has the highest priority of the external interrupt lines, and NIR5 has the lowest priority. 

INS8900 AND PACE TIMING AND INSTRUCTION EXECUTION 

PACE uses a combination of two clock signal inputs to time events internally within the 
microprocessor CPU. The clock signals and the resultant internal clock phases can be illus- 
trated as follows: 



PACE 

CLOCK 

SIGNALS 



Internal Clock 
Phase 











. 






. 1 




«..« '""^ " W7W, 


^ 


One Clock Period 


One Clock Penod 


One Clock Period 


One Clock Period 


Tl 


T2 


T3 


^4 


T5 


T6 


Ty 


T8 



















I 

clk" ^ r 



"LJ 



NCLK f| 



-rr^ 









r. 
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The INS8900 clock logic has been simplified. A single, uniform clock signal generates all timing as follows: 















^1 




'""" " "'""■' 


" 


One Clock Period 


One Clock Period 


One Clock Period 


One Clock Period 


Tl 


T2 


^3 


T4 


T5 


T6 


T7 


T8 



















CLKX 



J/ — \ i — \ r~i \ v-[ 



INS8900 
AND PACE 
MACHINE 
CYCLE 



INS8900 
AND PACE 
MACHINE 
CYCLE 
TYPES 



Several points should be noted regarding INS8900 and PACE timing. The internal clock phases 
(Tl through T8) are meaningless to external logic since they are not accessible, nor are they 
needed for any external synchronization purposes. We have shown them merely because they 
will simplify later discussions of data input/output operations. Four clock periods constitute a 
single machine cycle. Most instructions require between four and seven machine cycles for ex- 
ecution. 

So far as external logic is concerned, there are only three types of machine cycles which can 
occur during execution of an instruction: 

1) A data input operation (read) during which external logic must present a word of data to the 
CPU. 

2) A data output operation (write) during which the CPU transmits a word of data to external 

logic. 

3) An internal operation during which no CPU-initiated activity occurs on the System Bus. 

All instructions include one or more data input machine cycles, and two or more interna! operation machine cy- 
cles. Only a few instructions include data output machine cycles. The first machine cycle of any instruction's execution 
must, of course, be an instruction fetch operation — which to external logic is simply a data input cycle. Let us 
therefore begin by examining the data input machine cycle. 

Figure 1-5 illustrates timing for a standard data input machine cycle. Notice that the address 

is only present on the data lines for the first portion of the machine cycle. The NADS signal is sent 

out approximately in the center of the time interval during which the address data is valid; 

therefore, either the leading edge or trailing edge of NADS can be used to clock the address data. 

The IDS signal is sent out at about the same time as the address information is taken off the data lines — well before 

the time when input data is expected by the CPU. This gives external logic time to prepare the input data. The input 

data needs to be valid only for a short time interval later in the machine cycle. Exact timing is given in the data sheets 

at the end of this chapter. 



INS8900 AND 
PACE DATA 
INPUT CYCLE 



Internal Clock 
Phase 

D00-D15 

NADS 

IDS 










1 


Tl 


T2 


T3 


T4 


T5 


T6 


T7 


T8 


Tl 


T2 








i 


1 i i 






1 


[address Data Output Valid] 


wmm 


■^:^^^w////m 








\ 






1 1 












/ 








\ 




• 




1 




\ 

1 






1 1 
1 1 









Figure 1-5. INS8900 and PACE Data Input Timing 
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Figure 1-6 illustrates timing for a standard data output cycle. The address-output portion of 
the cycle is identical to that of the data input cycle just described; the ODS signal is sent out at 
the same part of the cycle as IDS was. At approxinnately the same time that ODS is sent out, the 
output data word is placed on the data lines. The output data remains valid beyond the end of the 
ODS signal so that the trailing edge of ODS can be used as the clock for external data latches. 



INS8900 AND 
PACE DATA 
OUTPUT 
CYCLE 



Internal Clock 
Phase 

D00-D15 

NADS 

ODS 














1 


Tl 


T2 


T3 


T4 


T5 


T6 


T7 


TS 


Tl 


"^2 






i J i 




1 1 i 
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\ 7 

1 
1 


1 
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Figure 1-6. INS8900 and PACE Data Output Timing 



The data input/output cycles just described allow approximately two clock periods for ex- 
ternal logic to respond. If this time interval is too short, the EXTEND signal input to the CPU 
can be used to lengthen the I/O cycle by multiples of the clock period (one clock period equals 

two internal clock phases). The EXTEND signal can be placed high during address time or im- 
mediately after the start of IDS or ODS, but it must be high before the end of internal clock 
phase 6 as shown in Figure 1-7. 



INS8900 AND 
PACE EXTEND 
SIGNAL FOR 
SLOW I/O 
OPERATIONS 



T2 



T3 



T4 



T5 



T6 



One Clock 
Period 



17 



T8 



One Clock 
Period Extension 



Tl 



T2 



I Input Data 



DO0-D15 - 
(For Input Cycle) | 



Address Data Out 



I Valid I 



I 



DO0-D15 
(For Output Cycle) i 

NADS, 



Address Data Out 



I 



Output Data Valid 



A T 



IDS/ODS 



EXTEND ' 



I 



\ 



Figure 1-7. Using the EXTEND Signal to Lengthen I/O Cycles 
The timing shown in Figure 1-7 provides the minimum I/O cycle extension of one clock period. 
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The maximum extension permitted by PACE is 2 microseconds; so with a clock period of 750 nanoseconds, this 
means that only two clock period extensions can be added to an input/output cycle. The second clock period extension 
is achieved by holding the EXTEND signal high for one additional clock period beyond the timing shown in Figure 1-7. 
The INS8900 has no nnaximum permitted extension. 

Notice that the EXTEND signal does just what its name implies; it sinnply extends the duration of the data transfer por- 
tion of an I/O machine cycle. The trailing edge of the IDS or ODS signal is delayed and, for data input, the time until 
valid input data must be present is delayed. On data output cycles, the valid data is simply maintained on the data lines 
by the CPU for an extended period of time. 

The EXTEND signal can also be used to suspend CPU input activity. This use of EXTEND will be described later 
under the heading of Direct Memory Access. 

THE INITIALIZATION OPERATION 

A NINIT low signal input to the CPU initializes the microprocessor. The NINIT signal is the equivalent of the Reset 
signal described for other microcomputers in this book. While NINIT is held low, CPU operations are suspended; IDS 
and ODS are reset low. NINIT must be held low for a minimum of eight clock periods to give the CPU time to respond. 
After NINIT goes high again, this is what happens: 

1) The internal Stack Pointer is cleared. 

2) All flags and interrupt enables are set low (except Level Interrupt Enable which is set high). 

3) The Accumulators contain arbitrary values. 

4) The Program Counter is set to zero. 

5) 1 6 to 24 clock periods after NINIT returns high, the NADS signal is output high. The first instruction is thus fetched 
from memory location zero (OOOOiq). 

Figure 1-8 illustrates the timing for the initialization operation. Note that the NINIT signal is shown going low after 
power and clocks are both stable. The NINIT signal must be applied whenever the CPU is powered-up; if NINIT is held 
low before clocks and/or power have stabilized, the NADS and NHALT output signals may have undefined states for 
eight clock pulses after the trailing edge of NINIT. 



Power and Clocks Stabilized 



POWER 
AND CLOCKS 



NINIT 



NADS 



IDS/ODS 




•16 to 24 Clock Periods- 




Begin to fetch instruction from 
nnemory address 0000, ^ 



Figure 1-8. INS8900 and PACE Initialization Timing 



THE HALT STATE AND PROCESSOR STALL OPERATIONS 

Most microprocessors described in this book have a Hold state, w/hich typically describes a CPU condition dur- 
ing which there is no CPU- initiated activity on the System Busses; external logic can then perform Direct 
Memory Access operations. The INS8900 and PACE CPUs have an equivalent state that can be initiated under pro- 
gram control or by external logic. When this state is initiated under program control (by executing a Halt instruc- 
tion) INS8900 and PACE literature calls it the Halt state; when initiated by external logic, it is called a Pro- 
cessor Stall. 

During normal program execution, the CPU NHALT control line provides a high output. When a 
Halt instruction is executed, the NHALT output is driven low to indicate that CPU activity is sus- 
pended. While in the Halt state, the NHALT output has a 7/8 duty cycle; that is, every eighth clock 
phase, the NHALT output goes high. If the NHALT output is merely used to drive an indicator on a 



INS8900 AND 
THE PACE 
HALT STATE 
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control panel, this 7/8 duty cycle is of little concern; but, if the NHALT signal is used as a logic signal, the 7/8 duty cy- 
cle nnust be accounted for. The Halt state is terminated by setting the CONTIIM input signal high for a minimum of 
16 clock cycles, and then resetting it low for at least four clock cycles, as shown in Figure 1-9 . CPU operation 
then resumes by executing the next instruction, that is, the instruction that follows the Halt instruction. 



Halt instruction executed 



NHALT 
(Output) 



I ^^i-iait instruction execi 

I I— H ^^ 



CPU operation resumes ->^ I 



A 



-r^ 



/A^J" 



1 Machine 
cycle 



CONTIN I 

(Input) I 



Trf 



J^ 



•4^ 



4 Clock I 
Cycles I 



■16 Clock Cycles Minimum- 



-Indefinite Duration- 



/f 



Figure 1-9. Terminating INS8900 or PACE Halt State 



NHALT AND CONTIN 
SIGNALS ARE 
MULTIFUNCTIONAL 



As we have just seen, the PACE NHALT and CONTIN signals are interrelated. We men- 
tioned earlier that these signals are also multifunctional. We will describe separately 
each of the functions that can be implemented with NHALT and CONTIN. Do not use 
these signals to implement more than one function unless your application absolutely 
requires the additional functions. Critical and complicated timing relationships are required by the CPU to differenti- 
ate between various functions. For PACE, but not the INS8900, timing is further complicated by some circuit problems 
in the CPU's interrupt system, which we will describe later. 



INS8900 
AND PACE 
PROCESSOR 
STALL 



PROCESSOR STALL 
AND LEVEL 
INTERRUPT 
SIMILARITIES 



The INS8900 and PACE CPU can be forced into the Halt state by external logic. INS8900 
and PACE literature defines this operation as a Processor Stall. A Processor Stall uses both 
NHALT and CONTIN as control signal inputs. Figure 1-10 shows the timing sequence re- 
quired. The NHALT input must be driven low by external logic to initiate the sequence. CPU 
operation is then suspended after execution of the current instruction is completed. The minimum 
response time is five clock cycles. The maximum response time is equal to the longest instruction execution time (refer 
to Table 1 -2 ). There is no maximum time limit for a Processor Stall. The CPU simply remains in the Halt state until it is 
terminated by the CONTIN input signal, which must be properly sequenced with the removal of the NHALT input, as 
shown in Figure 1-10 . 

Let us take another look at the beginning of the Processor Stall timing sequence. Notice 
that when the CPU has completed the current instruction and recognized the stall re- 
quest, the CONTIN output signal is briefly driven low by the CPU. This pulse is referred 
to as ACK INT (Acknowledge Interrupt) and can be used to let external logic know that the 
CPU is responding to the stall request. It may seem inappropriate for the CPU to provide an 
Acknowledge Interrupt response when we are initiating a Processor Stall. However, as we shall see later in this chapter, 
a Level Interrupt request begins with exactly the same timing sequence as a Processor Stall; in fact, the reac- 
tion of the CPU is the same for both operations until that point in the sequence where NHALT goes high. 
Therefore, the initial response of ACK INT is always sent out after NHALT is driven low. 

DIRECT MEMORY ACCESS OPERATIONS 

At the beginning of our Halt state and Processor Stall discussion we mentioned that these are the equivalent of Hold 
states provided by other microprocessors. But there are some significant differences between the INS8900 and 
PACE Halt state, and the Hold state described for other microprocessors in this book. Because of these 
differences, Direc^t Memory Access operations with PACE or the INS8900 are not straightf orward. 

The INS8900 and PACE CPUs never float their Data or Control Busses. But remember that the 
design of any realistic 1NS8900 or PACE system is going to require buffer/drivers for the data lines 
and control signals. The BTE, which is part of the PACE microcomputer family, performs this 
buffering function. 

Any bidirectional three-state buffer can be used to float INS8900 bus lines. In Figure 1-2 , 

1NS8208 devices are shown performing this function. Thus it is the control signals input to the 

BTE by PACE or to the INS8208 by the INS8900 that actually float bus lines at the proper time, in order to allow DMA 

operations. 
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® 
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® 
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■^f 
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(EXTERNAL CIRCUITS HIGH IMPEDANCE) 
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NOTES: 
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OVERRIDE PACE MOS OUTPUTS. 

2. ^^^ CROSSHATCH INDICATES "DON'T 
\^22!ud CARE" INPUT STATE. 

3. tg = DURATION OF EXTEND DURING 
PACE I/O CYCLES. TIMING ASSUMES 

NO OTHER EXTENDS AND NO SUSPENDS. 



Figure 1-10. Timing Diagram for Processor Stall Using 
NHALT and CONTIN Signals 

But we must have a way of determining whether the CPU is going to be using the System Busses. There are 
several methods of making this determination; we will conceptually examine each of them within the context of three 
different DMA schemes: 

1) DMA block data transfers initiated by the CPU 

2) DMA block data transfers initiated by external logic 

3) Cycle-stealing DMA transfers 

From a hardware point of view, the simplest method of implementing DMA in a PACE or 
INS8900 system is to have the CPU initiate block transfers of data. Consider the following 
approach. The CPU will treat an external DMA controller as a peripheral device and will estab- 
lish initial conditions such as starting address, word count, and direction (memory read or 
write). This information can be passed to the controller by treating its registers as memory 
locations and using Store instructions to write into the registers. When the required information has been passed, the 
CPU simply executes a Halt instruction. As we described earlier, when a Halt instruction is executed, the NHALT 
control output line from the CPU is driven tow (7/8 duty cycle). This signal could thus be used by the DMA con- 
troller as an indication that the CPU will not be using the System Bus and the DMA transfer can begin. When the 
transfer is completed, the DMA controller will use the CONTIN input to the CPU, as shown in Figure 1-9 , to 
terminate the Halt instruction. Normal CPU operation will then resume. 



CPU 

INITIATED 
DMA BLOCK 
DATA TRANSFERS 
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DMA BLOCK 
DATA TRANSFERS 
INITIATED BY 
EXTERNAL LOGIC 
IN PACE AND 
INS8900 
SYSTEMS 



Most microprocessors have a Bus Request input signal that can be used by external logic to re- 
quest access to the Systenn Busses. In a PACE or INS8900 system, the NHALT input signal 
can be used to force the CPU into a Processor Stall, as described earlier, and thus free 
the System Busses for DMA operations. The Acknowledge Interrupt (ACK INT) pulse on 
the CONTIN output line shown in Figure 1-10 is then equivalent to a Bus Grant signal, 
and the DMA controller may begin the data transfer. When the transfer is complete, the 
CONTIN line is used as a control input line to the CPU to terminate the Processor Stall. 

Cycle-stealing DMA operations typically transfer a single word via the System Busses during a CYCLE-STEALING 
brief interval when the CPU is not using the busses. With this method, CPU operations need DMA IN PACE 
not be stopped; instead, they are only slowed down slightly, or in some cases not affected at AND INS8900 
all. In order to implement cycle-stealing DMA, external logic must have a way of detect- SYSTEMS 
ing those time intervals when the CPU will not be using the System Busses. There are 
two ways that this can be accomplished with the INS8900 or PACE CPU. The first method involves the use of the EX- 
TEND input signal to the CPU to suppress or suspend input/output operations; the second method uses a special tech- 
nique to sense when the CPU is beginning an internal (non-1/0) machine cycle. 



EXTEND USED 
TO SUSPEND 
INS8900 AND 
PACE I/O 
DURING DMA 
OPERATIONS 



Earlier we described how to use the EXTEND input signal to lengthen the CPU input/output cy- 
cles. The EXTEND signal can also be used to prevent the CPU from beginning an I/O cycle, and 
thus ensure that the System Busses will be available to external devices for DMA operations. 

Figure 1-1 1 illustrates both uses of the EXTEND signal. The CPU looks at the EXTEND input sig- 
nal at internal clock phases T1 and T6. Notice that during I/O cycles the IDS orODS signal goes 
high at the beginning of T6 and low at the beginning of T1 . If EXTEND is high during T6, then ex- 
tra clock cycles are inserted after T8; this is the method that would be used to lengthen an I/O cy- 
cle. If EXTEND is high during T1 , then extra clock cycles are inserted between T3 and T4; this is the method we would 
use for DMA operations. 

The trailing edge of IDS/ODS indicates that the CPU has just completed an I/O cycle and is therefore not using the 
System Busses at this instant. By setting EXTEND high at this time, we suppress the beginning of another I/O cycle 
while we use the busses for a DMA transfer. 

Notice that we are merely lengthening the beginning of the machine cycle, and thus delaying that part of the machine 
cycle where the CPU might begin I/O activity. We do not know whether the current machine cycle will be an internal 
machine cycle or an I/O cycle, and we do not care. We have merely stolen the busses by slowing down the CPU. 
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Figure 1-11. Using PACE EXTEND Signal for Cycle-Stealing DMA 
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There are two drawbacks inherent in the EXTEND method of cycle-stealing DMA. First, whenever we use the System 
Busses for a DMA transfer, we slow down the operation of the CPU. Second, we must wait until the CPU has just com- 
pleted an input/output cycle before we can perform the cycle steal. Since only about one-third of the CPU machine cy- 
cles are used for I/O, this means that bus access for DMA will be quite limited. Both of these drawbacks can be elimi- 
nated if we can find some technique for determining when the CPU is performing an internal (non-1/0) machine cycle. 
We could then use the System Busses any time that the CPU is not using them (which is more than 60% of the 
time) and we could perform the DMA transfer without slowing down CPU operations. We shall now describe 
just such a technique. 

We stated earlier in this chapter that the internalclock phases (T1 through T8) are not availa- 
ble to external logic. However, National Semiconductor data sheets include a figure that shows 
circuits for internal drivers and receivers. A detailed examination of this figure reveals a very 
interesting and useful fact: the JC13 (Jump Condition 13) pin on the CPU is intended as an in- 
put signal; but, because of the way in which the receiver for this signal is designed, it also pro- 
duces an output pulse on the JC13 pin during every machine cycle. The output pulse occurs 
during T4 of each machine cycle, and we can use this fact to design a very efficient cycle-stealing DMA arrangement. 
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Figure 1-12. Idealized Circuit for Cycle-Stealing DMA During INS8900 and 
PACE Internal Machine Cycles 

Figure 1-12 shows a circuit that uses the output pulse provided by JC13 to implement cycle-stealing DMA. Recall 
that the CPU sends out a negative-going NADS pulse at T4 of every input/output cycle. This NADS signal is ANDed in 
our circuit with an external device's DMA Bus Request and applied to the D input of a flip-flop. The JC13 output pulse, 
which also occurs at T4, is inverted via a transistor and applied to the clock input of the flip-flop. Thus, if NADS is high 
at T4 (indicating that the current CPU machine cycle is not an I/O cycle) the flip-flop will be set if there is a Bus Request 
present. The output of this flip-flop is then used by external logic as a Bus Grant signal and the DMA transfer can be in- 
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itiated. Since we do not know whether or not the next cycle will be a CPU I/O cycle, we must terminate DMA activity on 
the bus prior to the next T4 time. In Figure 1-12 , this is accomplished using a divide-by-four counter. 

The CLK input to the counter is a combination of the Bus Grant signal and the TCLK signal which is available from the 
PACE STE. This results in the timing shown in Figure 1-13. Notice that this scheme makes the bus available for about 
7/8 of a machine cycle, or approximately 2.25 microseconds. If you refer back to Figure 14-10 you will notice that this 
is about the same length of time as was obtained by using the maximum duration of EXTEND. So. we have not in- 
creased the maximum time available for a DMA transfer. But, we have made two significant gains: DMA transfers can 
occur more frequently, and these transfers do not slow down CPU operations. 

We must add a final note of caution to the description of this otherwise straightforward DMA technique. There are 
several critical timing paths in the idealized circuit shown in Figure 1-12 . Both the JC13 pulse and the NADS signal 
occur at T4, although the trailing edge of NADS does occur slightly after the trailing edge of JC13. Therefore, the com- 
ponents used to provide CLK and D inputs to the flip-flop must be selected carefully to ensure that there is not a race 
condition. Additionally, we have shown the Bus Grant signal being reset at the end of T3. Since the leading edge of 
NADS occurs at T4, this timing relationship can be critical. However, if external devices such as address latches and 
decoders use the trailing edge of NADS, this timing should present no problems. 
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Figure 1-13. Timing for Cycle-Stealing DMA During INS8900 and PACE Internal Machine Cycle 

THE INS8900 AND PACE INTERRUPT SYSTEM 

The INS8900 and PACE CPUs have complete on-chip interrupt systems. Six separate levels of interrupts are 
provided: one internal and five external interrupt request inputs, including a non-maskable input. Priority logic is 
provided on the CPU, and all interrupts are vectored, thus eliminating any polling requirements. Because of the 
various ways in which interrupts can be initiated, and also because of a few problems that exist in the PACE in- 
terrupt system, we wilt divide our description of the system into three parts: 

1 ) Low priority external interrupts 

2) Internal (Stack) interrupts 

3) Non-maskable (Level 0) interrupts 

But first, let us take an overview of the 1NS8900 and PACE interrupt system. 
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Figure 1-14. Internal View of INS8900 and PACE Interrupt System 
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Figure 1-14 depicts the interrupt logic that is contained on the CPU. The highest priority in- 
terrupt request is the non-maskable Level interrupt request, which is initiated using 
the NHALT control input to the CPU. The lowest priority interrupt request is NIR5. 

The Stack Interrupt and each of the four lower-priority external interrupt requests can be 
individually enabled or disabled by setting or clearing associated bits (IE1 - IE5) in the 
Status and Control Flag register. Notice in Figure 1-14 that these bits are shown as provid- 
ing the 'R' input to a latch. The 'S' input to each of these latches is the actual interrupt request 
line. The significance of this is rather subtle. It nneans that an interrupt request need not supply 
a continuous low level until it is acknowledged. Instead, any pulse exceeding one PACE clock 
period will set the associated interrupt request latch: this allows narrow tinning or control 

pulses to be used as interrupt request inputs. Note, however, that the 'R' input to the latches overrides the 'S' input. 
Therefore, if the individual Interrupt Enable flag is reset, it not only prevents the latch from being set by interrupt re- 
quests, it will also clear a previously latched request that may or may not have been serviced. If this logic is not clear to 
you, you should study the characteristics of the RS flip-flop. 

A master interrupt enable (lEN) flag is also provided in the Status and Control Flag register. lEN must be set true 
to allow any of the latched interrupt requests to be recognized by the CPU. 



The CPU checks for interrupts at the beginning of every instruction fetch. If an interrupt request is INS8900 AND 

present (and enabled), the instruction fetch is aborted, the contents of the Program Counter are PACE 

pushed onto the Stack, and the master interrupt enable (lEN) is set low. The CPU then loads the INTERRUPT 

Program Counter with the address vector for your interrupt service routine and executes the in- RESPONSE 
struction contained at that address. (We'll describe the address vectors in the next paragraph.) 

The interrupt request just described requires a total of 28 clock cycles from the time the interrupt is recognized by the 
CPU untilthe time when the first instruction of your interrupt service routine begins execution. 



Memory locations 0002ig through OOOSig are used as pointer locations or address vectors. 

You load each of these locations with the starting address of the interrupt service routine for each 
interrupt as follows: 

INTERRUPT POINTER FOR 
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8 Level Interrupt Origin 

The level interrupt is a special case which we will describe on its own. But first let us look at interrupts in 
general. 

When the CPU responds to an interrupt, it loads the Program Counter with the contents of memory locations 2 through 
6, depending on the specific level of interrupt that is being acknowledged. Control is thus vectored to the proper ser- 
vice routine. Suppose, for example, memory location 4 contains the value 2A30i 5. If an interrupt request occurring at 
pin NIR3 is acknowledged, then during the acknowledge process the contents of the Program Counter are saved on the 
Stack, following which the value 2A30i6 is loaded into the Program Counter. Had the value 4728-16 been in memory 
location 4, then 4728i6 would have been loaded into the Program Counter instead of 2A30i6 Thus, whatever memo- 
ry address is stored in the memory location associated with the interrupt being acknowledged, this address will be 
loaded into the Program Counter, becoming the starting address for the specific interrupt service routine to be ex- 
ecuted. 



As part of the interrupt response we've just described, the CPU sends out a low-going pulse on INS8900 

the CONTIN line. Refer back to Figure 1-10 and associated text for a description of the ACK AND PACE 

INT pulse. The last instruction executed by your interrupt service routine must be a Return- INTERRUPT 

from-lnterrupt (RTI) instruction. This instruction sets lEN high to re-enable interrupts, then ACKNOWLEDGE 

pulls the top of the Stack into the Program Counter. This returns program control to the point AND RETURN 

where it was interrupted. The RTI instruction does not clear the internal Interrupt Request FROM INTERRUPT 
latch; therefore your interrupt service routine must reset the latch (using a Pulse Flag instruc- 
tion), or the same interrupt request will still be present after the RTI instruction has been executed. Once the latch has 
been cleared, it can then be re-enabled for subsequent interrupt requests. 



1-21 



The interrupt sequence does not save the contents of any registers except the Progrann Counter. If 
the program that was interrupted requires that the contents of CPU registers be saved and then 
restored, your interrupt service routine must perform these operations. 
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The CPU's response to a Stacl< interrupt is as described for external interrupts. However, the inter- 
rupt request is generated internally by the CPU chip; it can be caused either by a Stack Full or a 
Stack Empty condition. Remember that the 1 0-word Stack is part of the CPU chip. It consists of an 
internal RAM and a pointer that can address Stack words through 9. A Stack Empty interrupt re- 
quest is generated whenever the pointer is at and a Pull instruction is executed. A Stack Full in- 
terrupt request occurs when the pointer is at 7 (eight entries on the Stack) and a Push instruction 
is executed to fill the ninth word. The tenth word of the Stack will then be used as part of the in- 
terrupt response to store the Program Counter contents. Unless you intend to extend the Stack out 
into main memory, your application program will not require a Stack Empty or Full interrupt. These interrupts become 
error conditions and can be avoided by careful programming. 

If your program is treating the Stack Empty and Stack Full interrupts as error conditions, then you can disable Stack in- 
terrupts, in which case the full ten words of the Stack are available for nested interrupts and subroutines. Of course, 
this means that a Stack Full or Empty condition, should it occur, will become an undetected error, with unpredictable 
consequences. _^ 



When using PACE, but not the INS8900, there is an additional reason for not using the Stack in- PACE 
terrupt capability unless you really need it. PACE has an internal circuit problem that can cause STACK 
improper interrupt response. If a Stack interrupt request occurs at the same time as an NIR3 INTERRUPT 
or NIR5 interrupt request, the Stack interrupt address vector will be incorrectly accessed PROBLEMS 
from location instead of location 2. The solution recommended in PACE literature is to load ^— ^^^— 1«^ 
both of these locations with the Stack interrupt vector. This apparently straightfonward solution is complicated by the 
fact that location also happens to be the initialization address; whenever the CPU is initialized, the first instruction ex- 
ecuted is the one that is contained in location 0. Thus, the word in location must serve a dual purpose: 

1) It serves as an instruction whenever the CPU is initialized. 

2) It serves as an address vector if a Stack interrupt occurs at the same time as NIR3 or NIR4. 

Here's an example. The object code for a Copy Flags to Register (CFR) instruction is 0400-)6 So, if locations and 2 
both contain a value of 0400i6 the problem is solved. Your Stack interrupt service routine would have to begin at 
memory address 0400i6' but you would be correctly vectored to that address regardless of whether or not the inter- 
rupt error we've just described occurs. On initialization, the first instruction executed would be the CFR instruction: this 
is not a very useful initialization instruction, but at least no damage is done. 

For a fuller discussion of this interrupt problem and the solution, refer to PACE literature. Also keep in mind that 
the problem has been fixed in the INS8900. 

The non-maskable (Level 0) interrupt cannot be disabled and differs from the other interrupt levels both in the 
way it is initiated and in the way the CPU responds to it. 



The Level interrupt request is initiated using the NHALT control input signal in com- INS8900 
bination with the CONTIN input line. Figure 1-15 shows the timing relationships bet- AND PACE 
ween NHALT and CONTIN that are required to initiate the non-maskable interrupt. If you NON-MASKABLE 

compare this figure with Figure 1-10 , you will notice that the Level interrupt request and (LEVEL 0) 
the Processor Stall begin in exactly the same way; NHALT is driven low by external logic and INTERRUPT 
held low for some time after a low-going pulse (ACK INT) has been sent out on the CONTIN 

line. The only difference between the two operations is towards the end of the timing sequence. For a Processor Stall, 
NHALT is allowed to return high while CONTIN is still high; for a Level interrupt, the CONTIN line must be driven low 
by external logic before the NHALT line is allowed to go high. This critical timing sequence is the only way that the CPU 
has to differentiate between a Processor Stall and a Level interrupt. Notice that this Level interrupt timing sequence 
never requires external logic to drive CONTIN high. Therefore, if you're using the CONTIN line for any of its other nnulti- 
ple functions (including the ACK INT output pulse) you can merely tie CONTIN to ground and use NHALT to initiate the 
Level interrupt. 



The response of the CPU to the Level interrupt is subtly different from its response to INS8900 

other interrupts. These subtle differences are related to the slightly different purpose of a non- AND PACE 

maskable interrupt versus a normal program interrupt request. A non-maskable interrupt is LEVEL 

typically used only when there is a catastrophic error or failure (such as loss of power) or to imple- INTERRUPT 

ment a control panel for program development or debug purposes. Both of these uses require that RESPONSE 
an asynchronous, unplanned program termination have a minimum effect upon system status; 
that is, you want to leave behind a picture of the system as it looked immediately before the program termination oc- 
curred. 
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Figure 1-15. Initiating iNS8900 and PACE Level Interrupt 
Using NHALT and CONTIN Signals 

Remember that other levels of interrupts store the contents of the Program Counter or the Stack and reset the lEN flag 
in the Status and Control Flag register. This sequence obviously alters the "picture" of the CPU, since both Stack con- 
tents and Status and Control Flag register contents are changed. To avoid this, the Level interrupt response by the 
CPU uses an external memory location to store the contents of the Program Counter Memory location 0007i5 holds 
the address of the memory word where the Program Counter will be stored. The contents of the Status and Control Flag 
register are unaltered. CPU internal circuitry resets an "IRO INT ENABLE flag to prevent another interrupt from being 
recognized (refer to Figure 1-16 ), but this is not discernible to you. After the Program Counter has been saved in the 
designated memory location, the instruction contained in memory location OOOS-jg is executed; this is the first instruc- 
tion of your Level interrupt service routine. Suppose, for example, that memory location 0007|5 contains the value 
FFOOi 6 Following a Level interrupt request, the Program Counter contents will be stored in location FFOO-| g. Follow- 
ing the Level interrupt acknowledge, the actual instruction stored in memory location OOO815 is executed. 

Note that the Level interrupt acknowledge sequence has not altered anything within the CPU that is discernible to 
you or to a program; the Stack, Accumulators, and Status and Control Flag register are all unchanged. Additionally, 
avoiding use of the Stack ensures that there will not be a Stack overflow — and in consequence a Stack interrupt will 
not be generated by this interrupt response sequence. 

The normal Return-from-lnterrupt (RTI) instruction that must be executed at the end of your inter- 
rupt service routine causes the Program Counter to be restored from the Stack. Since the Level 
interrupt sequence does not utilize the Stack to store the Program Counter, a different tech- 
nique must be used to return control to the interrupted program. First you must execute a Set 
Flag (SFLG) or Pulse Flag (PFLG) instruction, referencing bit 15 in the Status and Control Flag register. This bit always 
appears to be set to a '1', but must be referenced in this case to enable lower levels of interrupts. Next you must ex- 
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ecute a Jump Indirect (JMP@) through the location pointed to by the contents of memory location 0007i6 to restore 
the original Program Counter contents. 

PACE, but not the INS8900, has some Level interrupt circuit problems. 
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If a Level interrupt occurs within the 1 2-clock-cycle period following the recognition of 
any other interrupt, PACE will either perform a Processor Stall (which we described earlier) 
or PACE will execute the Level interrupt — but using the wrong pointer address. In short, 
you don't know what might happen under these circumstances. There is a solution for this prob- 
lem. It requires that external logic allow NHALT to be applied to the PACE CPU only while the NADS signal is present, 
provided no Acknowledge Interrupt (ACK INT) has occurred since the last NADS pulse. ACK INT is accompanied by a 
negative-going pulse on the CONTIN line. Sound complicated? It is. 

The circuit shown in Figure 1-16 is reproduced from PACE literature and solves the problem we've just described. We 
won't attempt to describe here how this circuit solves the problem. Note that this circuit only takes care of Level in- 
terrupt problems; if you also want to use NHALT and CONTIN to cause a Processor Stall, you must design additional ex- 
ternal logic. 

Once again, we must advise that these interrupt system problems exist in PACE CPU chips. The INS8900 has 
none of these problems. 

THE INS8900 AND PACE INSTRUCTION SET 

Table 1-1 summarizes the I NS8900 and PACE instruction set. 

The primary memory reference instructions have typical minicomputer addressing modes. These instructions will also 
be used as I/O instructions, since external devices are identified via selected memory addresses. 

In Table 1-1 , "direct addressing options" means the instruction can reference memory using any 
of the direct or direct indexed addressing options described earlier. 

"Indirect addressing options" similarly specifies any of the indirect addressing options described 
earlier. 
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Both Branch and Skip instructions are provided, and each differs significantly from the philoso 
phies described in Volume 1 , Chapter 6. 

There are 1 6 conditions that can cause a Branch, as shown in Table 1 -3 . Notice that three of the conditions are deter- 
mined by external inputs JC13, 14, and 15. If a Branch-on-Condition is true, then the displacement which is added to 
the Program Counter is an 8-bit signed binary number as described in Volume 1, Chapter 6. 

There are three varieties of Skip-on-Condition instructions. SKNE, SKG and SKAZ compare the contents of an Ac- 
cumulator to a memory location which is addressed using direct or direct indexed addressing. Based on the results of 
the comparison, the instruction following the Skip may or may not be executed. These three instructions are therefore 
combined Skip and Memory Reference instructions. 

ISZ and DSZ identify a memory location using direct or direct indexed addressing; the contents of the addressed 
memory location are incremented (ISZ) or decremented (for DSZ); if after the increment or decrement operation the 
memory location contains a value, then the Skip is performed. 

The AISZ instruction adds an 8-bit, signed binary number to the contents of an Accumulator; if the result is 0, a Skip is 
performed. 

These Skip instructions will be very familiar to minicomputer programmers, and on most microcomputers are 
equivalent to a secondary Memory Reference or Immediate Operate instruction, followed by a Branch-on-Condition in- 
struction. 
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Figure 1-16. Circuit to Prevent Conflicts Between PACE Level 
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The following symbols are used in Table 1-1 : 

ACO Accunnulator 

C Carry status 

CC 4-bit Condition Code described in Table 15-3 

D Any Destination register 

DATA8 8-bit binary data unit 

DISP(X) Direct or indexed addressing operands as explained in the text. 

@DISP(X) Indirect addressing operands as explained in the text. 

EA The effective address generated by the specified operands. 

f 4-bit quantity selecting a bit in the Flag Word. 

FW Flag Word described in the text. 

lEN Interrupt Enable status 

I A 1-bit unit determining whether LINK is included in the shift/rotate. 

L Link status 

n Seven bits deternnining how nnany single bit shift/rotates are perfornned. 

Overflow status 

PC Progrann Counter 

r Any register of the Accunnulator: ACO, AC1, AC2 or ACS 

S Any Source register 

ST Top word of on-chip Stack. 

x<y,z> Bits y through z of the quantity x. For example, r<7,0> is the low-order byte of the specified register. 

[ ] Contents of location enclosed within brackets. If a register designation is enclosed within the brackets, 
then the designated register's contents are specified. If a memory address is enclosed within the brackets, 
then the contents of the addressed memory location are specified. 

[[ ]] Implied memory addressing; the contents of the memory location designated by the contents of a register. 

A Logical AND 

V Logical OR 

-V- Logical Exclusive-OR 

'— Data is transferred in the direction of the arrow. 

•■ ► Data is exchanged between the two locations designated on either side of the arrow. 

Under the heading of STATUSES in Table 1-1 , anX indicates statuses which are modified in the course of the instruc- 
tion's execution. If there is no X, it means that the status maintains the value it had before the instruction was ex- 
ecuted. 
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Table 1-1. INS8900 and PACE Instruction Set Summary 



TYPE 


MNEMONIC 


OPERAND(SI 


BYTES 


STATUSES 


OPERATION PERFORMED 


C 


o 


L 


PRIMARY 

MEMORY REFERENCE 

AND I/O 


LD 
LD 
ST 
ST 
LSEX 


r.DISP(X) 

0.@DISP(X) 

r.DISP(X) 

O.ODISPIX) 

O.DISP(X) 


2 
2 
2 
2 
2 








[r]-[EA] 

Load any Accumulator, direct addressing options. 
[ACO]-[EA] 

Load Primary Accumulator, indirect addressing options. 
[EA]-[r] 

Store any Accumulator, direct addressing options. 
[EA]-[ACO] 

Store Primary Accumulator, indirect addressing options. 
[ ACOl—E EAKsign extended) 

Load a signed byte into Primary Accumulator; extend sign bit into high order byte. Direct 

addressing options. 


SECONDARY 
MEMORY REFERENCE 
(MEMORY OPERATE) 


ADD 

DECA 

SUBB 

AND 

OR 


r.DISPIX) 
0,DISP(X) 
0,DISP(X) 
0,DISP(X) 
O.DISP(X) 


2 
2 
2 
2 
2 


X 
X 
X 


X 
X 
X 




[r]-[r]+[EA] 

Add to any Accumulator, direct addressing options. 
[ACOl — [ACO]-;-lEA]^[C] 

Add decimal with Carry to any Accumulator, direct addressing options. 
[ACO]-[ACO]-[EA] + lC] 

Subtract from Primary Accumulator with borrow, direct addressing options. 
[ACQ] -[ACQ] A [EA] 

AND with Primary Accumulator, direct addressing options. 
(ACO]-[ACO]V[EA] 

OR with Primary Accumulator, direct addressing options. 


UJ 

1- 
< 

5 

UJ 

s 


JMP 
JMP 


r.DATAS 

DISP(X) 
@DISP(X) 


2 

2 
2 








[ r< 7.0 > ]— DATA8 (sign extended) 

Load immediate into any Accumulator. DATA8 is an 8-bit signed binary value. The sign bit 

is propagated through 8 high order bits. 
[PCI— EA 

Jump by loading the effective direct address into the Program Counter, 
[PCI— EA 

Jump by loading the effective indirect address into the Program Counter. 



Table 1-1. INS8900 and PACE Instruction Set Summary (Continued) 



TYPE 


MNEMONIC 


OPERAND(SI 


BYTES 


STATUSES 


OPERATION PERFORMED 


C 





L 




JSR 
JSR 


DISP(X) 
@DISP(X) 


2 
2 








[ST1-[PC] 
[PCl-EA 

Jump to subroutine direct. As JMP direct, but push old Program Counter contents onto 

Stack. 
[ST]-[PC] 
[PC]-EA 

Jump to subroutine indirect. As JMP indirect, but push old Program Counter contents onto 

Stack. 


5 s 

1° 


CAI 


r.DATAS 


2 








[ r]^[ r] +DATA8 (sign extended) 
Complement contents of any register, then add immediate data. 


u 
u 

CD O 


BOC 


CCDISP 


2 








If CC true; then [PCl-EA 
Branch on CC true, as defined in Table 14-3. 


MEMORY REFERENCE 
AND SKIP 
(SEE TEXT) 


SKNE 

SKG 

SKAZ 


r,DISP(X) 
O.DISP(X) 
O.DISP(X) 


2 
2 
2 








If [rl^CEAl: then [PCl-CPCl+l 
Skip if any Accumulator not equal. 

If [ACO] > [EA]; then [PC]-[PCl+ 1 
Skip if Primary Accumulator greater. 

If ([ ACO] A I EA]) = 0; then [ PC]-[ PC] + 1 
Skip if AND with Primary Accumulator is zero. 



Table 1-1. INS8900 and PACE Instruction Set Sunrmnary (Continued) 



TYPE 


MNEMONIC 


OPERAND(S) 


BYTES 


STATUSES 


OPERATION PERFORMED 


C 





L 


MEMORY 
REFERENCE 
OPERATE 
AND SKIP 


ISZ 
DSZ 


DISP(X) 
DISP(X) 


2 
2 








[EA]-[EA]+1 

If [ EA] = 0: then [ PC] — [ PC] + 1 

Increment memory, skip If zero. 
[EA]-[EA]-1 
If [EA]=0; then [PC]-[PC]+1 

Decrement memory, skip if zero. 


^ & z 


AISZ 


r,DATA8 


2 








[r]-[r]+DATA8 

If [r] =0; then [PC]— [PCl + 1 
Add immediate to any Accumulator. Skip if zero. DATA8 is an 8-bit signed binary immedi- 
ate data value. 


E CC 

W M O 

lU UJ 
E E 


RCPY 
RXCH 


S,D 
S.D 


2 
2 








[D]-[S] 

Move contents of any Accumulator (S) to any Accumulator (D). 

[D]< -[SI 

Exchange contents of any Accumulators. 


lU 

. E 
E Ul 

lu a. 
1- o 
2 OC 

2|S 
E m 

a 

Ui 

E 


RADD 
RADC 
RAND 
RXOR 


S,D 
S.D 
S.D 
S.D 


2 
2 
2 
2 


X 
X 


X 
X 




[D]-[S]-i-[D] 

Binary add any Accumulator to any Accumulator. 
[D]-[S]-H[D]-H[C] 

Binary add with Carry any Accumulator to any Accumulator. 
[D]-[S]A[D] 

AND any Accumulator vi/ith any Accumulator 
[D]-[S]¥[D] 

Exclusive-OR any Accumulator with any Accumulator. 


(9 lU 
U Q. 
E O 


SHL 
SHR 
ROL 
ROR 


r.n.l 
r.n.1 
r.n.l 
r.n.l 


2 
2 
2 
2 






X 
X 
X 
X 


Shift any Accumulator left n bits. Simple if 1 = 0; through Link if 1 = 1. 
Shift any Accumulator left n bits. Simple if 1 = 0. through Link if 1 = 1. 
As SHL. but rotate. 
As SHR. but rotate. 



Table 1-1. INS8900 and PACE Instruction Set Summary (Continued) 



TYPE 


MNEMONIC 


OPERAND(S) 


BYTES 


STATUSES 


OPERATION PERFORMED 


C 





L 


u 

(0 


PUSH 

PUSHF 

PULL 

PULLF 

XCHRS 

RTS 


r 

r 

r 
DISP 


2 
2 
2 
2 
2 
2 


X 


X 


X 


[ST]-[r] 

Push any Accumulator contents onto Stack. 
[ST]-[FW] 

Push flags onto Stack. 
[rl-tSTl 

Pull top of Stack into any Accumulator. 
(FW]-[ST] 

Pull top of Stack into flags. 
[ST] [r] 

Exchange contents of any Accumulator with top of Stack. 
(PCI — [ST] + DISP 

Return from subroutine. Move sum of DISP and top of Stack to PC. DISP is an 8-bit signed 

binary number. 


a 

E 
E 
UJ 

Z 


RTI 


DISP 


2 








[PC]-[ST]+DISP 
[lEN]— 1 
Return from interrupt. Like RTS. but enable interrupts. 


M 

3 
(- 

0» 


CFR 
CRF 
SFLG 
PFLG 


r 
r 
f 

f 


2 
2 
2 
2 


X 


X 


X 


[rl-[FW] 

Copy flags to any Accumulator. 
[FW]-[r] 

Move any Accumulator contents to flags. 
[FW<f>]— 1 

Setflagf to 1. (f=Oto 15). 
[ FW<f>]— 1 for four clock periods 

Pulse flag f (invert flag status for four clock periods). (f= to 15). 




HALT 




2 








Halt 



The following symbols are used in Table 1-2: 



aa 

bb 

cccc 

ee 

ffff 

I 

nnnnnnn 

PP 

QQ 

X 

XX 



Two bits choosing the destination register. 

Two bits choosing the Index register 

Four bits choosing the Condition Code. See Table 1-3. 

Two bits choosing the source register. 

Four bits selecting a bit in the Flag Word. 

One bit determining whether Link is included in a shift or rotate. 

Seven bits determining how many single bit shifts or rotates are performed. 

8-bit signed displacement 

Eight bits of immediate data 

A "don't care" bit 

A "don't care" byte 



Table 1-2. INS8900 and PACE Instruction Set Object Codes 



INSTRUCTION 


OBJECT CODE 


BYTES 


MACHINE CYCLES | 


TOTAL 


INTERNAL 


INPUT 


OUTPUT 


ADD r,DISP(X) 


inOaabb 
PP 


2 


4 


2 


2 




AISZ r.DATAS 


OlinOaa 
QO 


2 


5/6 


4/5 


1 




AND 0,DISP{X) 


101010bb 
PP 


2 


4 


2 


2 




BOO CC.DISP 


OlOOcccc 
PP 


2 


5/6 


4/5 


1 




CAI r,DATA8 


OniOOaa 
QO 


2 


5 


4 


1 




CFR f 


OOOOOIaa 
XX 


2 


4 


3 


1 




CRF f 


OOOOIOaa 
XX 


2 


4 


3 


1 




DECA 0,DISP(X) 


lOOOIObb 
PP 


2 


7 


5 


2 




DSZ DISP{X) 


lOIOIIbb 
PP 


2 


7/8 


4/5 


2 


1 


HALT 


OOOOOOxx 
XX 


2 


- 


- 


1 




ISZ DISP(X) 


10001 Ibb 
PP 


2 


7/8 


4/5 


2 


1 


JMP DISP (X) 


0001 lObb 
PP 


2 


4 


3 


1 




JMP «/)DISP(X) 


1001 lObb 
PP 


2 


4 


2 


2 




JSR OISP(X) 


OOOIOIbb 
PP 


2 


5 


4 


1 




JSR t'«)lSP(X) 


lOOIOIbb 
PP 


2 


5 


3 


2 




LD r,DISP(X) 


irOOaabb 
PP 


2 


4 


2 


2 




LD 0,®DISP(X) 


lOIOOObb 
PP 


2 


5 


2 


3 




LI r.DATAS 


OlOIOOaa 
QQ 


2 


4 


3 


1 




LSEX O.DISP(X) 


lomibb 

PP 


2 


4 


2 


2 




OR O.DISPIX) 


10100 tbb 
PP 


2 


4 


2 


2 





1-31 



Table 1-2. INS8900 and PACE Instruction Set Object Codes (Continued) 



INSTRUCTION 


OBJECT CODE 


BYTES 


MACHINE CYCLES | 


TOTAL 


INTERNAL 


INPUT 


OUTPUT 


PFLG f 


OOllffff 
Oxxxxxxx 


2 


6 


5 






PULL r 


011001aa 
XX 


2 




3 






PULLF 


OOOIOOxx 
XX 


2 




3 






PUSH r 


01 lOOOaa 
XX 


2 




3 






PUSHF 


000011 XX 
XX 


2 




3 






RADC S.D 


OOmOlaa 
eexxxxxx 


2 


• 


3 






RADD S.D 


OllOIOaa 
eexxxxxx 


2 




3 






RAND S.D 


OlOIOIaa 
eexxxxxx 


2 




3 






RCPY S.D 


0101 llaa 
eexxxxxx 


2 




3 






ROL r.n.l 


OOlOOOaa 
nnnnnnni 


2 


5+3n 


4 + 3n 






ROR r.n.l 


OOlOOIaa 
nnnnnnni 


2 


5 + 3n 


4 + 3n 






RTI 


Olinixx 
PP 


2 


6 


5 






RTS 


lOOOOOxx 
PP 


2 


5 


4 






RXCH S.D 


OllOHaa 
eexxxxxx 


2 


6 


5 






RXOR S.D 


0101 lOaa 
eexxxxxx 


2 


4 


3 






SFLG f 


OOllffff 
1 xxxxxxx 


2 


5 


4 






SHL r.n.l 


OOlOIOaa 
nnnnnnni 


2 


5 + 3n 


4 + 3n 






SHR r.n.l 


00101 laa 
nnnnnnni 


2 


5 + 3n 


4 + 3n 






SKAZ O.DISP (X) 


lOinObb 
PP 


2 


5/6 


3/4 


2 




SKG O.DISP (X) 


1001 llbb 
PP 


2 


7/8 


5/6 


2 




SKNE r.DISP (X) 


1111aabb 
PP 


2 


5/6 


3/4 


2 




ST r.DISP (X) 


noiaabb 
PP 


2 


4 


2 


1 


1 


ST 0,@DISP(X) 


lOIIOObb 
PP 


2 


4 


1 


2 


1 


SUBB O.DISP (X) 


lOOIOObb 
PP 


2 


4 


2 


2 




XCHRS r 


OOOIIIaa 
XX 


2 


6 


5 


1 





*AII instructions may take additional cycles if Extend Read and Extend Write are implemented. 
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Table 1-3. Branch Conditions for INS8900 and PACE BOC Instruction 



Condition 
Code (CO 


Mnemonic 


Condition 


0000 


STFL 


Stack Full (contains nine or more words). 


0001 


REQO 


(ACO) equal to zero (see Note 1). 


0010 


PSIGN 


(ACO) has positive sign (see Note 2). 


0011 


BITO 


Bit of ACO true. 


0100 


BIT1 


Bit 1 of ACO true. 


0101 


NREQO 


(ACO) is nonzero (see Note 1 ). 


0110 


BIT2 


Bit 2 of ACO is true. 


0111 


CONTIN 


CONTIN (continue) input is true. 


1000 


LINK 


LINK is true. 


1001 


lEN 


lEN is true. 


1010 


CARRY 


CARRY is true. 


1011 


NSIGN 


(ACO) has negative sign (see Note 2). 


1100 


OVF 


OVF is true. 


1101 


JC13 


JC13 input is true (see Note 3). 


1110 


JC14 


JC14 input is true. 


1111 


JC15 


JC15 input is true. 



NOTES: 

1. If selected data length is 8 bits, only bits through 7 of ACO are tested. 

2. Bit 7 is sign bit (instead of bit 15) if selected data length is 8 bits. 

3. JC13 is used by INS8900 and PACE Microprocessor Development System and is not accessible 
during prototyping. 



THE BENCHMARK PROGRAM 

For PACE, our standard benchmark program adopts this modified form: 

LOAD I/O BUFFER ADDRESS INTO AC2 
LOAD ADDRESS OF FIRST FREE TABLE BYTE 
MOVE TO ACS 
LOOP LD 0,0(2) LOAD NEXT BYTE FROM I/O BUFFER 

STORE IN NEXT TABLE BYTE 
INCREMENT AC2 
INCREMENT ACS 

DECREMENT I/O BUFFER LENGTH. SKIP IF ZERO 
RETURN FOR MORE BYTES 
MOVE ACS CONTENTS TO ACO 
RESTORE ADDRESS OF FIRST FREE TABLE BYTE 

in order to take advantage of INS8900 and PACE indirect addressing, three memory locations are reserved on page as 
follows: 

lOBUF holds the beginning address of the I/O buffer. 

TABLE holds the address of the first free byte in the permanent data table. 

lOCNT holds the number of data words in the I/O buffer. 



LD 


2,I0BUF 


LD 


0.@TABLE 


RCPY 


0,3 


LD 


0,0(2) 


ST 


0,0(3) 


AISZ 


2.1 


AISZ 


3,1 


DSZ 


lOCNT 


JMP 


LOOP 


RCPY 


3,0 


ST 


0.@TABLE 
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Memory, as organized for the benchmark program will look like this: 



Memory 
Addresses 


-^ 0010 

■^ 0011 

-^ 0012 

0013 

0014 

xxxx 

yyyy 


MEMORY 




lOBUF 


xxxx 


1 


TABUE 


yyw 


2 Data on Base Page 


lOCNT 








) 




1 








■^ Start of I/O Buffer 












— 






















































* First free word of D 









Suppose the benchmark program rules arbitrarily require that a displacement be stored in the first word of the data ta- 
ble, and that this displacement be added to the address of the first word of the data table in order to compute the ad- 
dress of the first free data table word; 



DISP 



DISP 



■ First data table word 



First free data table word 



Now the instructions: 



LD 
RCPY 



0.@TABLE LOAD ADDRESS OF FIRST FREE TABLE BYTE 
0,3 MOVE TO AC3 



must be replaced by these instructions: 

LD 3,TABLE LOAD BEGINNING ADDRESS OF DATA TABLE 



LD 
RADD 



0.0(3) 
0,3 



LOAD DISPLACEMENT TO FIRST FREE TABLE WORD 
ADD DISPLACEMENT TO AC3 



The new displacement must be restored to the first data table word. The instructions: 



RCPY 
ST 



3,0 MOVE AC3 CONTENTS TO ACQ 

0,@TABLE RESTORE ADDRESS OF FIRST FREE TABLE BYTE 
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LD 


OJABLE 


CAI 


0,1 


RADD 


0.3 


RCPY 


3.0 


LD 


3.TABLE 


ST 


0.0(3) 



must be replaced by these instructions: 

LOAD BEGINNING ADDRESS OF DATA TABLE IN AGO 

FORM TWOS COMPLEMENT 

SUBTRACT AGO FROM ACS TO FORM DISPLACEMENT 

MOVE DISPLACEMENT TO AGO 

LOAD BEGINNING ADDRESS OF DATA TABLE IN AC3 

SAVE DISPLACEMENT IN FIRST FREE TABLE WORD 

Forcing an INSB900/PAGE programmer to conform to programming logic suited to some other microcomputer's in- 
struction set only proves that the two microcomputers have different instruction sets. 

THE PACE DP8302 SYSTEM TIMING ELEMENT (STE) 

The STE is a very elementary clock device used with PACE, but not with the INS8900; it accepts inputs from an 
external crystal and generates the MOS clock signals for PACE, plus a pair of TTL-level clock outputs that can 
be used for synchronizing system operations. Figure 1-17 illustrates the pin assignments of the STE. 




PIN NAME 

XI, X2 
CLK, NCLK 
CK. NCK 
TCLK. TCLK* 
EXTC 
LCK. LCK* 



DESCRIPTION TYPE 

External crystal connections Input 

Damped MOS clocks to PACE Output 

Undamped MOS clocks to PACE Output 
TTL clocks to microcomputer system Output 

External oscillator option Input 
Non-overlap capacitor connection 
Power and Ground 



Figure 1-17. DP8302 System Timing Element (STE) Pins and Signals 



STE CLOCK 
FREQUENCY 



The frequency of the MOS clocks output by the STE is one-half the input crystal frequency. The 
STE is designed to operate with a 2.6667 MHz crystal. The MOS clock frequency is thus 1.3333 
MHz which results in a clock period (tp) of 750 nanoseconds (tp = 1/f); this is the optimal clock 
period for the PACE CPU. 

Two pairs of MOS clock outputs are generated by the STE; NCLK/NCLK* and NCK/NCK*. The first pair of outputs 
contain a 25 il series of damping resistor; typically, these outputs will be used in circuit board layouts where the STE- 
to-PACE interconnect lines are less than two inches. The other MOS outputs. NCK and NCK*. are undamped, and you 
can select some other value of series damping resistors that might be better suited for your particular board layout 

In addition to the +5V and -12V power supplies typically needed with MOS devices, the 
PACE CPU has a third power supply requirement: a substrate bias voltage (Vbb) of +8V 
must be applied to the CPU chip. Since it is unlikely that any other devices in your microcom- 
puter system would require this voltage level, the need for a third external system power source 
can be eliminated by providing a voltage converter circuit Figure 1-18 shows a circuit that 
generates the required Vbb voltage level; the circuit requires only a few components and uses 
one of the STE's TTL clock outputs as a charge pump' for the circuit. 



GENERATING 
THE PACE 
SUBSTRATE 
BIAS 
VOLTAGE 
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Figure 1-18. Circuit to Generate Substrate Bias Voltage (Wqq) for PACE CPU 

THE PACE BIDIRECTIONAL TRANSCEIVER ELEMENT (BTE) 



The DP8300 BTE is an 8-bit device that provides an interface between the PACE MOS-level signals and the 
TTL-level signals required by other devices in a microcomputer system (the BTE is not used in INS8900 
systems). If you refer to Figure 1-1 at the beginning of this chapter, you will see that a typical PACE nnicrocomputer 
systenn requires three BTEs: two are used to buffer the CPU's 16 address/data lines, and the third is used as a TTL 
driver for the CPU's control signal outputs (NADS, ODS, IDS, F1 1 - F14). 

Figure 1-19 shows the pin assignments for the BTE. 




WBD» 
GND 



PIN NAME 

MBI/O 00 - 07 
BDI/0 00 - 07 
CE1, CE2». 
STR», WED* 



V, 



CC 



GND 



DESCRIPTION 

MOS Bus Data Lines 
TTL Bus Data Lines 
Mode Control Signals 

+ 5V Power and Ground 



TYPE 

Input/Output 
Input/Output 
Input 



Figure 1-19 BTE Signals and Pin Assignments 
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BTE MODE 

CONTROL 

SIGNALS 



Table 1 -4 summarizes the operating modes of the BTE. 

WBD* is the main mode control signal; when this signal is low, the other control signals are ig- 
nored and the BTE simply converts the MOS signals from the CPU into TTL-level output signals. 
The TTL outputs have a high fan-out capability and can service up to thirty 50 milliampere loads. 
The BTE used to buffer the PACE control signals normally operates continuously in this 'drive-only' mode (Mode 
1) and is kept in this mode by simply connecting the WBD* signal to ground. 

The BTEs used to buffer bidirectional (address/data) lines must be switched back and forth between Modes 1 
and 2; Mode 1 is used for CPU data output and Mode 2 for CPU data input. The simplest way of accomplishing this 
is to continuously enable the CE1, CE2*, and STR* controls by connecting them to appropriate logic levels (-I-5V or 
ground) and then use the WBD* signal for directional control. For example, in a PACE system, the IDS signal from the 
CPU could be used as the input to WBD*. During a PACE data input cycle, IDS will go high at the appropriate portion of 
the cycle and place the BTE in Mode 2; IDS is low at all other times and the BTE will operate in Mode T 



Table 1-4. PACE BTE Truth Table 



MODE 

# 


CONTROL INPUTS 


MODE DESCRIPTION 


CE1 


CE2* 


STR* 


WBD* 


1 


X 


X 


X 





Receive MOS signals and 
drive TTL signals 


2 


1 








1 


Receive TTL signals and 
drive MOS signals 


3 











1 


Outputs in 

high-impedance 

state 





1 





1 


1 


1 





1 


4 


X 


X 


1 


1 


On positive-edge transition 
of STR*, latch into Mode 2 
or 3 as determined by state 
of CE1 and CE2* 



X = don't care 




Figure 1-20. Signal Connections to Control BTE in a DMA System 
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In a DMA or multiprocessor we will need to use BTE Mode 3 to place the BTE outputs in a high-impedance state 
and thus free the System Busses for use by other devices. In such a system an externally generated Bus Grant sig- 
nal could be used to place the BTE in Mode 3. Figure 1-20 illustrates one method of doing this: whenever the BUS 
GRANT signal is high, the BTE is in Mode 3. At other times the IDS signal operates as we've just described to switch the 
BTE back and forth between Modes 1 and 2. 

The fourth BTE mode uses a negative-to-positive transition on the STR* input to latch the state of CE1 and 
CE2', and then places the BTE in either Mode 2 or Mode 3. This latch mode function might be useful when the BTE 
is used as a simple input buffer. For example, in a system with multiplexed address/data lines (such as PACE), address 
outputs could be applied to CE1 and CE2*, and an address strobe signal (such as NADS) connected to STR*. Then, 
when the BTE is selected by the appropriate address bits, the trailing edge of the strobe signal will gate TTL data 
through the BTE and apply the data to the MOS lines of the CPU. When the BTE is not selected (addressed), its outputs 
will be in the high impedance state (Mode 3). 

USING OTHER MICROCOMPUTER SUPPORT DEVICES 
WITH THE PACE AND INS8900 

The INS8900 CPU has numerous control signals which allow general purpose microcomputer support devices to 
be included in an INS8900 system. 

Let us see how 8080A support devices might be used with the INS8900 CPU. First, we'll take an overview of 
the general CPU-to-device interface that all the 8080A family of devices expect. 

All of the 8080A family devices require that address information (or enabling/select signals derived from the ad- 
dress lines) be valid during the data transfer (read/write) portion of an input/output cycle. Recall that the INS8900 
data lines are multijalexed: at the beginning of an input/output cycle, the data lines are used to output address informa- 
tion; the address information is then removed and the data lines are used for the actual input or output of data during 
the latter portion of the I/O cycle. 



DEMULTIPLEXING 
THE INS8900 
ADDRESS/DATA 
LINES 



Thus, the first thing we must do to interface the INS8900 to an 8080A family device is 
to demultiplex the INS8900 address/data lines. There are several different approaches 
that we can use to accomplish the required demultiplexing. 

The most obvious way is to use D-type flip-flops or data registers with the INS8900 

NADS signal as the clock pulse. Here are some of the standard 7400 family devices that might be used: 

• 7475 Double 2-Bit Gated Latches with Q and Q Outputs 

• 7477 Double 2-Bit Gated Latches with Q Output Only 

• 74100 Double 4-Bit Gated Latches 
•74166 Dual 4-Bit Gated Latches with Clear 

• 74174 Hex D-Type Flip-Flops with Common Clock and Clear 
•74175 Quad D-Type Flip-Flops with Common Clock and Clear 

Some of these devices require that the NADS signal be inverted to provide the necessary clocking signal. Remember, 
though, that PACE address information is valid during both the leading edge (high-to-low transition) and trailing edge 
(low-to-high transition) of NADS; this generally simplifies the demultiplexing operation. 

In many systems you will not need to latch all 16 bits of address information since it would be an unusual applica- 
tion that required all of the 64K of address space that this provides. There will usually be some tradeoff between system 
address requirements (how many system devices require a latched Address Bus) and the type and amount of address 
decoding required. When a fully latched Address Bus is provided, then simpler nonlatched address decoders can be 
used. In fact, often address bits can then be used directly as device select signals, or simple AND/OR gate combina- 
tions can perform the decoding. 

The alternative method of demultiplexing the address/data lines is to use address decoding devices that are 
clocked by the NADS signal and provide latched outputs. These latched outputs can then be used as the 
device/chip select signals during I/O cycles. 

Many systems will use some combination of a fully latched Address Bus and simple or latched address 
decoders. In the discussions that follow, we will not generally describe in detail the method used to obtain the 
required addressing or select/enabling signals, since the method used is so dependent on the particular system 
that you are designing. 



1-38 



INS8900 CONTROL 
SIGNAL POLARITY 
CONSIDERATIONS 



Once the INS8900 address/data lines have been demultiplexed, the only major con- 
siderations we are left with are to ensure that the input/output control signals are of 
the proper polarity, and to verify that there are no timing problems. We will see that 
generally the INS8900 I/O control signals must be inverted to operate with the 8080A 
family of devices, although the 821 2 offers us a choice of using the IDS and ODS signals, in either their original or in- 
verted form. 

Now we will provide a few specific examples of how devices from the 8080A family can be used with the 
INS8900 CPU. 

In our first example the 821 2 I/O Port is used as a simple input port by the INS8900 CPU. 
The interconnections required are shown in the following figure: 




THE 8212 USED 
AS A SIMPLE 
INPUT PORT IN 
AN INS8900 
SYSTEM 



Data from 
external logic 



IDS 
(from INS8900) 



NADS 
(from INS8900) 



Tie MD to Ground. Now STB clocks 
latches and DS1, DS2 enable buffers. 



1 



NINIT 



Here, the INS8900 Address Strobe signal (NADS) is inverted and used as the STB input to the 8212. Since MD 
is tied to ground, the STB signal clocks the data into the 821 2: this will occur every time the INS8900 performs 
an input/output cycle, but the latched data will only be placed on the System Bus when t he 82 12 is selected. 
We accomplish device selection by applying a negative-true decoded address signal to the DS1 input and then 
using the INS8900 IDS strobe signal as the DS2 input. Now, whenever the proper address is decoded, the IDS 
signal will cause the data that was previously latched by NADS to be placed on the System Bus for input to the 
INS8900. The timing would look like this: 



NADS 



STB 



DIO - DI7 



DS1 



DS2 (IDS) 



DO0-DO7 




Latched data output 
onto System Bus 
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Notice that the data from external logic will be latched whenever NADS occurs. The actual selection of the 821 2 and 
input of the latched data to the INS8900 nnight not occur for quite Sonne time. Frequently, this arrangement will be 
completely acceptable. If not, then an input-with-handshaking arrangement, which we will describe next, might pro- 
vide a better solution. 

Before we proceed to our next example, let us make one more general comment about interfacing devices to 
the INS8900 CPU. 

The INS8900 is a 16-bit microcomputer: it can transfer 16 bits of parallel data in a single input or output cycle. 
All of the other devices that we will be discussing are 8-bit devices. Frequently, you may not need the full 
width of the 16-bit Data Bus when transferring data between the CPU and external logic. In these cases, you 
can simply connect the data lines to/from the support device to the less significant data lines (DO - D7) of the 
INS8900 System Bus, as we have shown in our first example. Masking of the unused, more significant data bits 
would then be handled under program control. 

When you are going to utilize the full 16 bits of the Data Bus, you merely connect two 8-bit devices in parallel, 
as described in more detail for the CP1600 in Chapter 2. One device would be connected as we've already de- 
scribed; the data lines of the other device would then be connected to the more significant bits (D8 - D15) of 
the System Bus. All other connections to the two devices (device select signals, strobe signals, etc.) would be 
identical. 

In this example, we will use the 8212 interrupt request signal INT to establish an input 
port with handshaking. The connection diagram is very similar to our first example: 



THE 8212 USED 
IN AN INS8900 
SYSTEM FOR 
INPUT WITH 
HANDSHAKING 




IDS 
(from INS8900) 



to INS8900 

Interrupt or 

Jump Condition 

Input Pin 



External logic strobes 
data into latches 



Tie MD to Ground. Now STB clocks 
latches and DS1, DS2 enable buffers 



Here, the device select signals are the same as in our first example. However, instead of using the INS8900 
NADS signal to clock data into the latches, we will require external logic to input the STB signal when it has 
data ready. When the data has been latched, the 8212 will output the INT signal, which will be used as the in- 
put to one of the INS8900 CPU interrupt request lines (NIR2 - NIR5) or Jump Condition inputs (JC13 - JC15). 

The CPU-will then execute a service routine program that will include an instr uctio n to read the data from the input 
port. This instruction will send out the input port's address, thus generating the DS1 signal, and then gate the latched 
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data onto the System Bus when the IDS signal is generated. When the latched data is read out of the 821 2, the INT sig- 
nal returns high to complete the transaction. This sequence is summarized by the following timing diagram: 



DIO - DI7 



STB 



INT 



DS1 



DS2 (IDS) 



DO0-DO7 



Data latched by 
external logic 




Interrupt request or 
Jump condition input 
to INS8900 CPU 



Latched data gated 
onto System Bus 



Using the 8212 as an output port in an INS8900 system requires a simple reversal of the 
connections we have described in the two preceding examples, and we will now use the 
ODS (Output Data Strobe) signal from the INS8900 instead of the IDS signal. 



THE 8212 USED 
AS AN OUTPUT 
PORT IN AN 
INS8900 SYSTEM 



Data from 
INS8900 CPU 
(System Bus) 



ODS 
(from INS8900) 



Select Signal ' 
derived from 
Address Lines 







DIO 




DOO 




^^^^ 


DI7 
STB 
MD 


8212 


DO? 
DS1 
DS2 

INT 


0-- 


1 \ ^ 










1 
1 



Data to external 
logic 



Select signals generated 
by external logic 



To external logic 



to INS8900 

interrupt lines 

or JC inputs 
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When the output port's address is sent out and decoded from the Address Bus, one input to the AND gate is enabled. 
The ODS signal the n go es high to generate the STB signal and latch the contents of the systenn Data Bus into the 821 2. 
This will cause the INT signal to go l ow a nd inform external logic that data has been loaded into the output port. The 
external logic will then generate the DS1 and DS2 signals to gate the data out of the latches. When the data has been 
gated out, the INT signal will return high. This low-to-high transition could be used as an interrupt request or jump con- 
dition in put to an INS8900 to enable output of new data. Notice that if we continuously enable the 8212 outputs 
by tying DS1 to ground and DS2 to +5V, then whenever the INS8900 loads a new data word into the latch, it 
will be immediately output to external logic. This approach may be more advantageous in some applications. 



Although the 8255 Programmable Peripheral interface (PPI) is a more complicated 
device than the 8212, interfacing the 8255 to an INS8900 CPU is no more complicated 
(from a hardware point of view) than the INS8900-to-8212 interfaces we've described. 
This is due to the programmability of the 8255; mode control is performed by your pro- 
gram instead of by hardwired signals. Let us look at an example to illustrate this point: 



8255 PPI 
DEVICES 
USED IN 
AN INS8900 
SYSTEM 



To /From 
INS8900 CPU 
(System Bus) 



Decoded Select 

signal derived 

from Address Bus 

From latched 
Address Bus 



From 

INS8900 

CPU 



IDS 



ODS 



NINIT 




^ 



The CS signal selects the 8255 and this signal would typically be the output of an address deco der. The AO and 
A1 inputs select one of the three I/O ports (A, B or C) or the 8255 Control registers. The RD and WR control sig- 
nals are obtained by simply inverting the IDS and ODS signals from PACE. A generalized timing diagram for in- 
put/output operations would look like this: 



NADS 



CS-A0-A1 




Select Device and Port Select 



V 



IDS (ODS) 



RD (WR) 



^ 



Data transferred 



^ 
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TWO 8255 
DEVICES USED 
FOR 16-BIT 
I/O PORTS 
WITH iNS8900 



THE 8251 
USART AND 8253 
PROGRAMMABLE 
COUNTER/TIMER 
USED IN INS8900 
SYSTEMS 



If two 8255s are used in parallel to provide 16-bit I/O ports, there is one special con- 
sideration beyond the general rules that we discussed earlier. Recall that mode control of 
the 8255 is acconnplished by writing data into one 8-bit Control register within the 
device. When wired in parallel, one 8255 would be connected to bits - 7 of the system 
Data Bus, and the other 8255 would be connected to bits 8-15. Therefore, when we 
send out a 16-bit control word from the INS8900 CPU to establish the desired mode of 
operation, the upper and lower bytes of the word must be identical. 

From a hardware point of view, interfacing either of these devices to an INS8900 CPU is 
no different than interfacing an 8255 PPI to the INS8 900. All we need to do is invert the 
IDS and ODS signals from the CPU to obtain RD and WR (or lOR and lOW) signals, and 
provide chip select and latched address bits for input to the devices. All other interfacing 
and usage considerations are software functions and are described in Chapter 4. We will 
not describe them here since those portions of the device descriptions apply regardless 
of the CPU being used. 

We will conclude our discussion of the use of 8080A devices in INS8900 systems by INS8900 AND 
comparing INS8900 System Bus signals with those of 8080A systems. This comparison 8080A SYSTEM 
will be a useful guide for interfacing any 8080A device to an INS8900 system. Table BUSSES 
1-5 is a summary of INS8900 System Bus signals and the corresponding signals availa- COMPARED 
ble in 8080A systems. Two separate columns are provided for 8080A signals: the first ap- 
plies strictly to the 8080A CPU; the right-hand column refers to the signals present in a typical three-chip 8080A 
system consisting of the CPU, an 8228 System Controller, and an 8224 Clock Generator and Driver. 

Since we have already discussed these signals in preceding paragraphs, we won't perform an item-by-item analysis of 
the table. Nonetheless, there are a few signals in this table that do need additional explanation. 

We have included the INS8900 BPS signal in the I/O Control Signal group although it is not the type of signal you 
would normally classify within this group. However, you will recall that when the BPS input is high, the INS8900 
operates in a Base-Page-Split mode; base page then consists of the top 1 28 words of memory and the bottom 128 
words of memory. In our earlier discussion of the BPS signal, we described how this mode can be used to simplify ad- 
dressing of I/O devices. If you refer back to that discussion, you will see that by doing a little address decoding we 
can come up with a signal that will tell us when the INS8900 is addressing an I/O device (as opposed to memory). 
Let us call this decoded signal I/O Device' (l/OD). Now, we can com bine this d ecoded signal with IDS and ODS as 
shown below to generate signals equivalent to the 8080A I/OR and l/OW signals. 



IDS 



;=o 



■I/OR 



l/OD. 



ODS 




l/OW 



And if we invert the l/OD signal we can generate the 8080A MEMR and MEMW signals. 



IDS' 



l/OD. 



ODSo 



> 






■MEMR 



■MEMW 
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One other portion of Table 1-5 requires some explanation. Notice that we have not drawn a line to separate the 
I/O control signals from the DMA-Related Signals. We've done this intentionally because there is some overlap- 
ping of functions with some of these signals. For exannple, the INS8900 EXTEND signal can be used either to extend 
1/0 cycles or to suspend I/O to allow DMA operations. We've also compared the INS8900 NHALT output signal to the 
8080A WAIT signal. This comparison is valid if limited to the CPU Halt state initiated in either system by a Halt instruc- 
tion. However, in 8080A systems the WAIT signal is also an acknowledgement to the READY or RDYIN input signals. 
There is no comparable EXTEND acknowledgement signal in PACE systems. 



The 6800 family includes many devices that might be useful in INS8900 systems. Unfor- 6800 SUPPORT 
tunately, all of these devices have one common requirement which effectively makes them DEVICES NOT 
inconnpatible for use in an INS8900 system. That requirement is enabling input signal E which COMPATIBLE 
should more accurately be described as a synchronizing signal. In 6800 systems, E is usually WITH INS8900 
generated by ANDing one of the primary system clock signals (<l>2) with the Valid Memory 
Address signal (VMA) from the 6800 CPU. The clock period of the resulting E signal can be no less than one microse- 
cond. The clock signals (CLK and NCLK) used in PACE systems, however, cannot have a clock period greater than 850 
nanoseconds, and therefore cannot be used to simulate the 6800 <t>2 signal. Therefore, we cannot recommend using 
6800 family devices in an INS8900 system. 

Table 1-5. Comparing INS8900 System Busses to 8080A System Busses 



SYSTEM BUS 


INS8900 
SYSTEM 
SIGNALS 


8080A 

CPU 

SIGNALS 


8080A SYSTEM 

(CPU, 8228. 8224) 

■ SIGNALS 


Bidirectional 
Data Bus 


D00-D15 
(16 Bits) 


D0-D7 
(8 Bits) 


DB0-DB7 
(8 Bits) 


Address Bus 


D00-D15 

Address information 
must be demultiplexed 
from Data Bus 


A0-A15 


A0-A15 


Control Bus 








I/O 

Control 

Signals 

DMA- 
Related 
Signals 


NADS 

Strobe signal used 
by external logic 
to demultiplex 
add'ress from 
Data Bus 


- 


- 


IDS 


DBIN 


MEMR and I/OR 


CDS 


WR 


MEMW and l/OW 


BPS 


— 


— 


EXTEND 


READY 


RDYIN 


NHALT (output) 


WAIT 


WAIT 


NHALT and 
CONTIN inputs 


HOLD 


HOLD 


CONTIN 
_ (.ACK INT output) 


HLDA 


HLDA 


- , 


— 


BUSEN 


Interrupt 
Signals 


NIR2-NIR5 


INT 


INT . 


CONTIN 

(ACK INT output) 


DO and SYNC 


INTA 


- 


INTE 


INTE 


Non-maskable 
Interrupt 
(CONTIN and 
NHALT inputs) 


- 


- 


Initialize 


NINIT 


RESET 


RESIN 


Jump Condition 
Inputs 


JC13- JC15 


- 


- 


Control Flag 
Outputs 


F11 -F14 


- 


- 
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DATA SHEETS 

This section contains specific electrical and timing data for the following devices: 

PACE CPU 
1NS8900 
PACE STE 
PACE BTE 



1-D1 



PACE CPU 



i>-C 






I Hill 






<?• 



> M 



MCf UCKASf 



13 . larUT MOTtCTION • -^^-1 



'JL 



FIGURE 4. PACE Drivar and Racaivar Equivalant Circuits 



external clock timing 

PACE requires non-overlapping true and complemented 
clock inputs as shown in Figure 5. Refer to Electrical 
Characteristics for timing specifications. 






I^clkZ]-* |.«-"nova -H ••— 'nc 



UNCLK • 



tJ 



where: 

tp- CLOCK PERIOD 

'NOVA " 'NOVB ' CLOCK NONOVERLAP 

'WCLK • 'WNCLK = CLOCK WIDTH 



FIGURE 5. Extarnal Clock Timing 



We reprint data sheets on pages 1-D2 through 1-D17 by permission of National Semiconductor Corporation. 



1-D2 



PACE CPU 



For systems utilizing memories with access times greater 
than 2 clock periods it may be desirable to use the 
EXTEND input to lengthen the I/O cycle by multiples 
of the clock period. Timing for this is shown in Figure 9. 
In the case of either input or output operations, the 
extend • should be brought true prior to the end of 
internal phase 6. The timing shown in Figure 9 will 
provide the minimum extend of one clock period. Hold- 
ing EXTEND true for n additional clock periods 
longer will cause an extension of n + 1 clock periods. 



In DMA or multiprocessor systems it may be desirable 
to prevent I/O operations by PACE when the bus is in 
use by another device. This may be done by using the 
EXTEND signal immediately following an IDS or ODS 
as shown in Figure 10. Alternatively, the extend timing 
of Figure 9 may be used, as the extend function occurs 
independent of whether there is an I/O operation, that 
is, whenever the internal clock phase 6 occurs. 
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FIGURE 6. Initialization Timing 
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Figure 7. Address Output and Data Input Tinning 
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FIGURE 8. Data Output Timing 
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FIGURES. 


Extend I/O Signal Timing 






absolute maximum ratings 








All Input or Output Voltages with +0.3V to - 


21.5V Storage Temperature Range 


-65°Cto+150°C 1 


Respect to Most Positive Supply 


Lead Temperature (Soldering 


,10 


300 C 


Voltage (Vqq) 


seconds) 






Operating Temperature Range 0°Cto+70"C 






electrical characteristics (t^ = o°c to +70°c, Vgs = +5v ±5%, \/qq = -i2v ±5%, Vbb = Vss + 3v ±o.5V) 


PARAMETER 


CONDITIONS 


MIN 


MAX 


UNITS 


OUTPUT SPECIFICATIONS 


D00-D15, F11-F14, ODS, IDS, NADS (These are 










open drain outputs which may be used to drive 










DS3608 sense amplifiers, or may be used with pull- 










down resistors to provide a voltage output.) 










Logic "1" Output Current (Except F1 1-F14) 


VOUT = 2.4V 


-1.0 


-5.0 


mA 


Logic "1" Output Current, F11-F14 (Note 7) 


VOUT = 2.4V 


-0.7 


-5.0 


mA 


Logic "0" Output Current 


VgG< VoUT^ Vss 




±10 


J^A 


NHALT, CONTIN (Low Power TTL Output.) 










Logic "1" Output Voltage 


lOUT = -650m A 


2.4 




V 


Logic "0" Output Voltage 


'OUT= 300M 




0.4 


V 


INPUT SPECIFICATIONS 


D00-D15, NIR2-NIR5, EXTEND, JC13-JC15, 










CONTIN, NINIT, NHALT (These are TTL 










compatible inputs.) (Note 2) 










Logic "1" Input Voltage 




vss-1 


Vss+0-3 


V 


Logic "0" Input Voltage 




vss-7 


VsS-4 


V 


Pullup Transistor "ON" Resistance 


V|N = VSS-1V 




7 


kfi 


(D00-D15) (Note 3) 










Pullup Transistor "ON" Resistance 


V|N = VSS-1^ 




5 


kfi 


(all others) 










Logic "0" Input Current (D00-D15) 


V||M = 0.4 




-1.8 


nnA 


Logic "0" Input Current (NHALT, CONTIN) 


V|N = 0.4 




-12 


mA 


Logic "0" Input Current (all others) 


V|N = 0.4 




-3.6 


mA 


Capacitance, Input and Output (except clocks) 


V|N = Vss,fT=500kHz 




20 


PF 


BPS (This is a MOS Level Input.) (Note 4) 










Logic "^" Input Voltage 




vss-1 


Vss+0.3 


V 


Logic "0" Input Voltage 




vgg 


vss-7 


V 


Logic "1" Input Current 


V|N = VSS-''V 




100 


AiA 


CLK, NCLK (These are MOS Clock Inputs) 










Clock "1" Voltage (Note 5) 




vss-1 


Vss+0-3 


V 


Clock "0" Voltage 




Vgg 


vgg+^ 


V 


Input Capacitance (Note 6) 




30 


150 


pF 


Bias Supply Current 


Vbb = Vss +30V 




100 


A/A 


VgG Supply Current 


tp = .65A1S, Ta = 25°C 




40 


mA 


Vss Supply Current 


tp = .65ms, Ta = 25° C 




85 


mA 


1 
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FIGURE 10. Suspend I/O Signal Timing 



TIMING SPECIFICATIONS (See Figures 5 to 10 for additional timing information.) 



CLK, NCLK (See Figure 5) (Referenced to 

10% and 90% Amplitude) 
Rise and Fall Time (tp, tf) 
Clock Width (tw CLK,tW NCLK) 
Clock Non-Overlap (t|MOVA, tiMQVB) 
Clock Period (tp) 

EXTEND 

Individual Extend Duration 
Extend Setup Time (tES) (Note 10) 
Extend Hold Time (tEH) (Note 13) 

Propagation Delay (too) 
NHALT, CONTIN (Note 9) 
NADS, IDS, ODS, D00-D15 (Note 8) 

DO0-D15 

Input Setup Time (tQS) (Note 1 1 ) 
Hold Time (tDH) (Note 12) 
Turn-on or Turn-off Time of Pullup 
Transistor (tpc) (Note 13) 

F11-F14 Pulse Flag (PFLG) Pulse Width 

NINIT Initialization Pulse Width 

NIR2-NIR5 Input Pulse Width to Set Latch 



CL = 20pF 
VOUT = 2.4V 



10 

300 

5 

.65 



100 
20 



200 



150 



4tp -300 
8 

1 



50 
375 



200 
100 



4tp +300 



clock periods 
clock periods 



Note 1 : Maximum ratings indicate limits beyond which permanent damage may occur. Continuous operation at these limits is not intended 

and should be limited to those conditions specified under dc electrical characteristics. 

Note 2: Pullup transistor provided on chip (See Figure 4.) 

Note 3: Pullup transistors on JC13, JC14, JC15 are turned on one out of 8 clock intervals. Pullup transistors on D00-D15 are turned on 

during last clock period of Input Data Strobe (IDS). Other pullup transistors are on continuously when in data input mode. 

Note 4: Pulldown transistor provided on chip. 

Note 5: Clamp diodes and series damping resistors may be required to prevent clock overshoot. 

Note 6: Capacitance is not constant and varies with clock voltage and internal state of processor. 

Note 7: For Vss > VquT > 2.0V output current is a linear function of VquT- 

Note 8: Delay measured from valid logic level on clock edge initiating change to valid current output level 

Note 9: Delay measured from valid logic level on clock edge initiating change to valid voltage output level. 

Note 10: With respect to rising edge of NCLK. (See Figure 9 and 10.) 

Note 11: With respect to falling edge of CLK. (See Figure 7.) 

Note 12: With respect to the valid "0" level on the falling edge of Input Data Strobe (IDS). (See Figure 7.) 

Note 13: With respect to valid logic level of appropriate clock. 
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INS8900 



Absolute Maximum Ratings 










Voltage at Any Pin with Resepct to 










Most Negative Supply (Vbb) -0.3 V to +20 V 










Operating Temperature Range C to +70 C 










Storage Temperature Range -65°C to +150°C 










Lead Temperature (soldering, 10 seconds) +300 C 










Electrical Characteristics 










(Ta = 0°C to +70°C, Vss = V, Vqd = +12 V ± 5%, Vcc = +5 V ± 5%, Vbb = -8 V ± 5%) 








Symbol 


Parameter 


Conditions 


Min 


Max 


Units 


OUTPUT SPECIFICATIONS 




D00-D15, F11-F14, ODS, IDS, NADS 












(These are low-power Schottky-compatible push-pull outputs.) 










VOH 


Logic "1" Output Voltage 


IOUT = -500mA 


2.4 




V 


Vol 


Logic "0" Output Voltage 
NHALT, CONTIN (low-power Schottky outputs) 


'OUT=900mA 




0.4 


V 


VOH 


Logic "1" Output Voltage 


•OUT = -250mA 


2.4 




V 


Vol 


Logic "0" Output Voltage 


IOUT = 600mA 




0.4 


V 


INPUT SPECIFICATIONS 




D00-D15, NIR2-NIR5, EXTEND, JC13-JC15, NINIT, 












CONTIN, NHALT (low-power Schottky inputs) 










VlH 


Logic "1" Input Voltage 




2.4 


VcC+1 


V 


V|L 


Logic "0" Input Voltage 




-1.0 


+0.8 


V. 


IL 


Input Leakage Current (except NHALX CONTIN, JC13- JC1 5) 


VSS<V|N<VCC+1 




40 


ma 


l|L 


Logic "0" Input Current, NHALT, CONTIN (Note 2) 


V|N = 0.4V 




-7.0 


mA 


l|L 


Logic "0" Input Current, JC13-JC15 (Note 2) 
BPS (This is an MOS level input.) 


V|N = 0.4V 




-3.0 


mA 


V|H 


Logic "1" Input Voltage 




vdd-1 


Vdd+1 


V 


V|L 


Logic "0" Input Voltage 




-1.0 


+0.8 


V 


l|H 


Logic "1" Input Current (Note 3) 
CLKX (This is an MOS level input.) 


V|N= 13.6V 




750 


ma 


VCIL 


Clock "0" Voltage 




-1.0 


+0.8 


V 


VCIH 


Clock "1" Voltage 




Vdd-1 


Vdd+1 


V 


C|N 


Input Capacitance 






20 


pF 


'dd 


Average Supply Current (Vq^) (Note 4) 


tp= 500 ns, Ta= 25°C 




100 


mA 


'CC 


Average Supply Current (Vcc) (Note 4) 


tp = 500 ns, Ta = 25°C 




10 


mA 


'bb 


Average Supply Current (Vqb) 


Vbb = -8V 




-200 


ma 
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INS8900 



Timing Specifications 



Symbol 



Parameter 



Conditions 



Min 



Max 



Units 



tr,tf 



tp 
tCLK-tNCLK 



tES 
tEH 

tDDl 
tDD2 

tDS 
tDH 

tPW 

tNW 

t|RW 



CLKX 

Rise and Fall Times (Note 5) 
(Referenced to 10% and 90% amplitude) 
Clock Period 

Pulse Width (Referenced to 50% amplitude) 
EXTEND 

Individual Extend Duration 
Extend Setup Time (Note 6) 
Extend Hold Time (Note 6) 

Propagation Delay 
NHALT, CONTIN (Note 7) 

NADS, IDS, ODS, D00-D15 (Note 7) 

D00-D15 

Input Setup Time (Note 6) 
Hold Time (Note 8) 

F11-F14 Pulse Flag (PFLG) Pulse Width 

NINIT Initialization Pulse Width 

NIR2-NIR5 Input Pulse Width to Set Latch 



500 

tp/2 - 5% 



70 
120 



30 

650 

tp/2 + 5% 



CL = 40pF, 

1 low-power Schottky load 

CL = 40pF, 1 INS8208load 



200 



200 



50 


4tp-300 



4tp + 300 



Notel: Maximum ratings indicate limits beyond which permanent damage may occur. Continuous operation at these limits is not 

intended and should be limited to those conditions specified under DC electrical characteristics. 

Note 2: NHALT, CONTIN, and JC13-JC15 logic "0" input currents specified when the internal chip loads are putting but a logic "1." 

Note 3: Pull-down transistor provided on chip. 

Note 4: Supply currents measured with 40 pF and INS8208 loads. 

Note 5: Clamp diode and series damping resistor may be required to prevent clock overshoot. 

Note 6: Measured with respect to appropriate valid logic level of CLKX. 

Note 7: Delay measured from valid logic level on CLKX edge initiating change to valid output voltage level. 

Note 8: With respect to the valid "0" level on the falling edge of jnput Data Strobe (IDS). 

Note 9: Typical load circuit: 

INS1900 RL = 3.6k (3.3k for testing) 

I Cl = 40pF 

I Vref=1-72V 







Note 10: Typical output delay versus load capacitance C|_ 
for load circuit in Note 9: 



Note 11: Typical Vdd supply current versus temperature. 
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Tming Waveforms 
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Figure 1. Extarnal Clock Timing (CLKX) 
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Figure 2. Initialization Timing 
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Figura 3. Addren Output and Data Input Timing 
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Timing Waveforms (continued) 
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Figure 4. Data Output Timing 
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Figure 5. Extend I/O Signal Timing 
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Figure 6. Suspend I/O Signal Timing 
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Tming Wavefbims (continued) 
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NOTES: 

1. EXTERNALLY GENERATED TTL INPUTS OVERRIDE PACE OUTPUTS. 

2. ^^ CROSSHATCH INDICATES "OONT CARE- INPUT STATE. 

@t, • DURATION OF EXTEND DURING PACE I/O CYCLES TIMING ASSUMES NO OTHER EXTENDS AND NO SUSPENDS. 

Figure 7. Relative Timing for Level-0 Interrupt Generation 
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NOTES: 

1. EXTERNALLY GENERATED TTL INPUTS OVERRIDE PACE OUTPUTS. 

2. Kg^ CROSSHATCH INDICATES "OONT CARE" INPUT STATE. 

@t, + DURATION OF EXTEND DURING PACE I/O CYCLES TIMING ASSUMES NO OTHER EXTENDS AND NO SUSPENDS. 

Figure 8. Relative Timing for Processor Stall 



The architecture of the INS8900 (shown in Figure 9) 
features a number of resources to minimize system pro- 
gram and read/write storage, increase throughput, and 
reduce the amount and cost of external support hard- 
ware. Principal resources that allow these efficiencies to 
be achieved include: 

Four 16-bit general purpose working registers available 
to the user reduce the number of memory load and store 
operations associated with saving temporary and inter- 
mediate results in system memory. 

An independent 16-bit status and control flag register 

automatically and continuously preserves system status. 
The user may operate on its contents as data, allowing 
masking, testing, and modification of several bit fields 
simultaneously. 

A ten-word (16-bit) last-in, first-out (LIFO) stack 
inherently decreases response time to interrupts while 
eliminating both program and read/write system storage 
overhead associated with storing stack information 
outside the microprocessor chip. 



Stack full/stack empty interrupts are provided to facili- 
tate off-chip stack storage in those applications where 
additional stack capacity is desirable. 

A six-level vectored priority interrupt system internal to 
the chip provides automatic interrupt identification, 
eliminating both program storage overhead and the time 
normally required to poll peripherals in order to identify 
the interrupting device. 

Three sense inputs and four control flag outputs allow 
the user to respond directly to specific combinations of 
status present in the microprocessor-based system, thus 
eliminating costly hardware, program overhead, and 
throughput associated with implementing these func- 
tions over the system data bus. 

A comprehensive set of input/output control signals 

provided by the internal control logic simplifies inter- 
faces to memory and peripherals and allows flexible 
control of I NS8900 operations. 

Single-phase 2.0 MHz clock input is easily generated with 
a minimum of external components. 
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recommended crystal specifications 






• AT-cut crystal 






« 2.6667 MHz ± 0.1%, fundamental 






mode 






• 5 mW maximum 






• 1 50 n maximum series resistance 




timing diagram 
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absolute maximum ratings ^^^ 

Supply Voltage (Vqc) 7.0 V 

(Vgg) -15.0 V 

Input Voltage 5.5 V 

Storage Temperature -65°Cto +150°C 

Lead Temperature (soldering, 10 seconds) 300°C 

dc electrical characteristics (Notes 2 and 3) 



operating conditions 



Supply Voltage (Vcc) 
(Vgg) 
Temperature 



Min. Max. Units 

4.75 5.25 V 

-11.40 -12.6 V 

+70 °C 



Parameter 



Conditions 



iVIin. 



Typ. 



Max. 



Units 



OUTPUT SPECIFICATIONS: 



TCLK.TCLK* (TTL Clocks) 


Vcc = 4.75 V 


Iqh = -1 mA 


3.65 


4.25 






Vqh Logic "1 " Output Voltage 


V 


Vol Logic "0" Output Voltage 


Vcc = 4.75 V 


loL = 32mA 




0.25 


0.4 


V 


Iqs Output Short Circuit Current 


(Note 4), Vcc = 


5.25V,Vo=0 


-10 


-33 


-55 


mA 


CK, NCK.CLK, NCLK 


loH = -100juA 


Vcc - 0.9 


4.5 






Vqh Logic "1" Output Voltage 


V 


Vol Logic "0" Output Voltage 


Vcc = 4.75 V 

Vgg = -1 1-4 V 


lou=100pA 




Vgg + 0.1 


Vgg + 0.25 


V 


loL= 5mA 




Vgg + 0.2 


Vgg + 0.5 


V 



INPUT SPECIFICATIONS: 



EXTC 




2.0 








V|H Logic "1" Input Voltage 


V 


I|H Logic "1" Input Current 


Vcc = 5.25 V 


V,fg=2.4V 






40 


/iA 


V,N = 5.5V 






1.0 


mA 


V|L Logic "0" Input Voltage 








0.8 


V 


1 iL Logic "0" 1 nput Current 


Vcc = 5.25 V 


V|L=0.4V 




-0.9 


-1.6 


mA 


VcLAMP Input Clamp Diode 


Vcc = 4.75 V 


llL = -12mA 




-0.8 


-1.5 


V 


POWER SUPPLY CURRENT 


Vcc = 5.25 V 




20 


30 




Ice Supply Current from Vcc 


mA 


Iqg Supply Current from Vgg 


Vgg = -12.6 V 




-40 


-55 


mA 



ac electrical characteristics crystal Frequency at 2.6667 MHz i a = 0°C to +70°C, Vcc - Vqg = +1 7 V ± 5% 


Symbol 


Parameter 


Limits 


Units 


Test 


Min. 


Typ. 


Max. 


Conditions 


tNOVl.tNOV2 


Non-Overlap Time 


5 


12 




ns 


See Note 5 


tpw 


MOS Clocks Pulse Width (NCLK, CLK, NCK, CK) 


300 


320 




ns 


See Note 5 


tR 


MOS Clocks Rise Time (NCLK, CLK, NCK, CK) 






40 


ns 


See Note 5 


tF 


MOS Clocks Fall Time (NCLK, CLK, NCK, CK) 






40 


ns 


See Note 5 


tPHl- tPH2 


TTL Clocks to MOS Clocks High Level Delay 


-40 




40 


ns 


See Note 5 


tPLV tPL2 


TTL Clocks to MOS Clocks Low Level Delay 






80 


ns 


See Note 5 


tTDl.tTD2 


TTL Clock to TTL Clock Delay 


-25 




25 


ns 


See Note 5 


tSTART 


Time Delay from Last Power Applied to MOS Clocks Stabilized 






100 


ms 


See Figure 7 



Notes: 

1 . "Absolute Maximum Ratings" are those values beyond which the safety of the device cannot be guaranteed. They are not meant to imply 
that the devices should be operated at these limits. The table of "Electrical Characteristics" provides conditions for actual device operation. 

2. Unless otherwise specified, min/max limits apply across the 0°C to +70°C temperature range and Vcc - 4.75 V to 5.25 V, Vqg = -11 .4 V 
to -12.6 V power supply range. All typicals are given for Vcc ^ 5.0 V, Vgg = -12 V, and T^ = +25°C. 

3. All currents into device pins are shown as positive; currents out of device pins are shown as negative. All voltages are references to ground 
unless otherwise noted. 

4. Only one output at a time should be shorted. 

5. The test conditions for measuring AC parameters are shown in Figures 2 and 3, with Cf = C2 = 60 pF, C3 = 80pF, C|\jov =60 pF. Load 
conditions for MOS clocks and TTL clocks are shown in Figures 4 and 5. Including probe and jig capacitance, C|_i = 20 to 80 pF, and 
Cl2 =40pF. 
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typical characteristics 
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absolute maximum ratings (Notei) recommended operating conditions 

Supply Voltage 7V Mirj MAX UNITS 

Input Voltage (All Inputs Except MBI/0 Input Active) 5.5V Supply Voltage (Vcc) 4 75 5 25 V 

Output Voltage 5.5V = v.v- 

MOS Bus Input Current ±10 mA Temperature (Ta) +70 C 

Storage Temperature -65°C to +1 50°C 

Lead Temperature (Soldering, 10 seconds) 300°C 

dc electrical characteristics (Notes 2 and 3) 


PARAMETER 


CONDITIONS 


MIN 


TYP 


MAX 


UNITS 


TTL BUS PORT (BDI/0 00-07) 


V|H Logical "1" Input Voltage 




2.0 






V 


ViL Logical "0" Input Voltage 








0.8 


V 


Vqh Logical "1" Output Voltage 


WBD* = 0.8V, 
MBI/O = 0.5 mA 


l0H = ~1 mA 


vcc-1.1 


Vcc-0.8 




V 


l0H= -5.2 mA 


2.4 


3.7 




V 


Vol Logical "0" Output Voltage 


WBD* = 0.8V, 
MBI/O = IOO/jA 


'OL = 20mA 




0.25 


0.4 


V 


'OL = 50 mA 




0.4 


0.5 


V 


'OS Output Short Circuit Current 


WBD* = 0.8V, MBI/O = 0.5 mA, 
VOUT = OV, Vcc = 5.25V, (Note 4) 


-10 


-35 


-75 


mA 


l|H Logicar'1" Input Current 


WBD* = 2V, V|H = 2.4V 






80 


ma 


l| Input Current at Maximum 
Input Voltage 


WBD* = 2V,V|H = 5.5V, 
Vcc = 5.25V 






1 


mA 


l|L Loglcar'O" Input Current 


WBD* = 2V,V|L = 0.4V 




-10 


-250 


^A 


VCLAMP Input Clamp Voltage 


WBD* = 2V,I|N= -12 mA 




-0.2 


-1.5 


V 


Iqd Output/Input Bus Disable Current 


WBD* = STR* = 2V, BDI/O = 0.4V 
to 4V, Vcc = 5.25V 


-80 




80 


^A 


MOS BUS PORT (MBI/O 00-07) 


Iq Logical "0" Input Current 


WBD* = 0.8V, lOL(TTL) = 50 mA, 
Vol < 0.5V, (Note 5) 


-5.0 




0.10 


mA 


ll Logical "1" Input Current 


WBD* = 0.8V, lOH(TTL) = -1 n^A, 
VoH > Vcc -1- IV, (Notes 5 and 6) 


0.50 




5.0 


mA 


Vq Logical "0" Input Voltage 


WBD* = 0.8V, lOL(TTL) = 50 mA, 
Vol < 0.5V 






0.8 


V 


Vi Logical "1" Input Voltage 


WBD* = 0.8V, lOH(TTL) = -1 ^A, 
V0H>VCC-1-1V 


2.0 


1.5 




V 


Vqh Logical "1 " Output Voltage 


WBD* = CE1 = BDI/O = 2V, 
l0H(M0S) = -1 mA, CE2* = 
STR* = 0.8V 


2.4 


3.3 




V 


Vol Logical "0" Output Voltage 


WBD* = CE1=2V, l0L(M0S) = 
5 mA, CE2* = STR* = BDI/O = 0.8V 




0.28 


0.5 


V 


Iqs Output Short Circuit Current 


WBD* = CE1 = BDI/O = 2V, 
Vcc = 5.25V, VoUT = OV, 
STR* = CE2* = 0.8V, (Note4) 


-7 


-15 


-45 


mA 


VCLAMP Input Clamp Voltage 


l||\) = -12mA 






-1.5 


V 


Iqd Output/Input Bus Disable Current 


MBI/O = 0.4V to 4V, Vcc = 5.25V 


-80 




80 


ma 


CONTROL INPUTS (WBD», CE1, CE2*,STR*) 


V|H Logical "1" Input Voltage 




2.0 






V 


ViL Logical "0" Input Voltage 








0.8 


V 


l|H Logical "1" Input Current 


V|N = 2.4V 






20 


ma 


l-j Input Current at Maximum 
Input Voltage 


V|N = 5.5V 






1.0 


mA 
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dc electrical characteristics (Continued) (Notes 2 and 3) 



PARAMETER 



CONDITIONS 



MIN TYP MAX UNITS 



CONTROL INPUTS (WBD*, CE1, CE2*, STR*) (continued) 










l|L Logical "0" Input Current 


V||M = 0.4V 




-250 


-400 


HA 


VCLAMP Input Clamp Voltage 


l|N = -12mA 




-0.85 


-1.5 


V 



POWER SUPPLY CURRENT 



Ice 



Power Supply Current 



Vcc = 5.25V 



70 



110 



mA 



Note 1: "Absolute Maximum Ratings" are those values beyond which the safety of the device cannot be guaranteed. They are not meant to 
imply that the devices should be operated at these limits. The table of "Electrical Characteristics" provides conditions for actual device operation. 
Note 2: Unless otherwise specified, min/max limits apply across the 0°C to +70°C temperature range and the 4.75V to 5.25V power supply range. 
All typicals are given for Vqc = 5V and T^ - 25°C. 

Note 3: All currents into device pins are shown as positive, out of device pins are negative. All voltages are referenced to ground unless otherwise 
noted. 

Note 4: Only one output at a time should be shorted. 

Note 5: The MBI/0 Input Characteristic Graph illustrates this parameter and defines the regions of guaranteed logical "0" and logical "1" out- 
puts. See equivalent input structure for clarification. When the MBI/0 input is loaded with a high impedance source (open), the TTL output will 
be in the logic "0" state. 

Note 6: The maximum MOS bus positive input current specification is intended to define the upper limit on guaranteed input clamp operation. 
At higher input currents (up to the absolute maximum rating) clamp operation is not guaranteed but TTL bus logic state is valid and no device 
damage will occur. 

Note 7: In most applications the MOS bus data lines are higher impedance and more sensitive to noise coupling than TTL bus lines. Conservative 
design practice would dictate routing MOS bus lines away from high speed, low impedance TTL lines and MOS clock lines or providing a ground 
shield when they are adjacent. 



ac electrical characteristics Vcc = 5v±5%, TA = o°cto+70°c 



PARAMETER 



CONDITIONS 



MIN 



TYP 



MAX 



UNITS 



DATA TRANSFER SPECIFICATIONS 



Receiving Mode (BDI/O Bus to MBI/0 Bus) 


WBD* = 3V, Cl= 15 pF, 
R L = 1 kfl, (Figures 4 and 6) 


tpdO 




17 


40 


ns 




tpdl 




20 


40 


ns 


Driving Mode (MBI/O Bus to 


WBD* = CE1 = 0V, 
STR* = CE2* = 3V, 
CL = 50pF, Rl= 100 n, 
(Figures 3 and 5) 


tpdO 




40 


60 


ns 


BDI/O Bus) 


tpdl 




40 


60 


ns 



TRANSCEIVER MODE SPECIFICATIONS 



Select Bus 














tQS 


Chip Enable Data Set-Up 


(Figure 1) 


45 


23 




ns 


tDH 


Chip Enable Data Hold 


(Figure 1) 









ns 


tES 


Set-Up 


(Figure 1J 









ns 



TTL Data Bus (BDI/O 00-07) 



tBDOD 


Bus Data Output Disable 


Cl = 5 pF, Rl = 100 n. (Figure 1) 


5 


20 


50 


ns 


tBDOE 


Bus Data Output Enable 


Cl = 50 pF, Rl = 100 n, (Figure 1) 




25 


80 


ns 


tBD IE 


Bus Data Input Enable 


(Figure 1) 




30 




ns 


tBD ID 


Bus Data Input Disable 


(Figure 1) 




30 




ns 



MOS Data Bus (MBI/O 00-07) 



tMBOD 


MOS Bus Output Disable 


Cl = 15 pF, Rl = 1 kfi, (Figure 1) 


15 


50 


100 


ns 


tMBOE 


MOS Bus Output Enable 


Cl = 15 pF, Rl = 1 kfi, (Figure 1) 




50 


100 


ns 


tMB ID 


MOS Bus Input Disable 


(Figure 1) 




55 




ns 


tMB IE 


MOS Bus Input Enable 


(Figure 1) 




20 




ns 



Select Bus 



tCLR 



Clear Previous Chip Enable 



(Figure 2) 



25 



50 
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switching time waveforms and ac test circuits 



/' 



y^ 



jk 



/■ 



-^ — tBO OE 



h 



\ 



h 



;r-^ 



^ INPUT ACTIVE y/i^, 



W//A MBI/0 00-07 W///A "«>l'0 00-07 

'M OUTPUT ACTIVE iVM INPUT ACTIVE 



AV^ 



A V- 



/ 



^Q V 



- h- 



V- 



^^^^§^^^ TRI jTATEf v^ 



^^ BDI/0 00-07 
SSS^ OUTPUT ACTIVE 



^ h- 



^MBI/O 00-07 X\S 



BIE f-^ 



INPUT 

WAVEFORM 

(NOTE 1 



" '" 7 V 

IM 1 5V \ 5 

') OV f V 



\ 



FIGURE 3. BDI/0 Bus 
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This input network simulates the actual drive characteristic of the PACE outputs 
FIGURE 5. MBI/O to BDI/O ac Loads 
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FIGURE 4. MBI/O Bus 
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FIGURE 6. BDI/O to MBI/O ac Loads 
Note 1: Freq = 1 MHz, duty cycle = 50%, tR = tp < 10 ns (refer to Figures 5 and 61. 
Note 2: All capacitance values include probe and jig capacitance (refer to Figures 5 and 61. 
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Chapter 2 
THE GENERAL INSTRUMENT CP1600 



The CP1600 and the TMS 9900 were the first two NMOS 16-bit microprocessors commercially available. Even 
a superficial inspection of the CP1600 siiows it to be more powerful than the National Semiconductor PACE (or 8900), 
yet the CP1600 is not widely used. This is because General Instrument does not support the CP1600 to the extent 
that National Semiconductor originally supported PACE, or most manufacturers support their 8-bit microprocessors. 

General Instrument's marketing philosophy has been to seek out very high-volume customers; General Instru- 
ment supports low-volume customers only to the extent that this support would not require substantial investment on 
the part of General Instrument. 

From the viewpoint of the low-volume microprocessor user. General Instrument's marketing philosophy is unfortunate. 
The CP1600 is an ideal microprocessor for the more sophisticated videogames that are appearing, and its rich instruc- 
tion set and capable architecture make it an ideal choice for data processing terminals and home computer systems. 
However, due to its limited support, potential low-volume CP1 600 customers are likely to choose another equally capa- 
ble product. 

Three CP1600 parts are available, differentiated only by the clock speeds for which they have been designed. 

The CP1600 requires a 3.3 MHz, two-phase clock and generates a 600 nanosecond machine cycle time. 

The CP1600 requires a 4 MHz, two-phase clock and generates a 500 nanosecond machine cycle time. 

The CP1610 requires a 2 MHz, two-phase clock and generates a 1 microsecond cycle time. 

In addition to the CP1600 microprocessors themselves, the CP1680 Input/Output Buffer (lOB) is described in 
this chapter. Additional support devices for the CP1600 may be found in An Introduction to Microcomputers : 
Volume 3 — Some Real Support Devices. 

The sole source for the CP1600 is: 

GENERAL INSTRUMENT 
Microelectronics Division 
600 West John Street 
Hicksville, New York 11802 

There is no second source for the CP1 600. General Instrument has a policy of discouraging second sources for its 
product line. 

The CP1600 is fabricated using NMOS ion implant LSI technology; the device is packaged as a 40-pin DIP. 

Three power supplies are required: -I- 12V, -I-5V and -3V. 

THE CP1600 MICROCOMPUTER SYSTEM OVERVIEW 

Logic of our general microcomputer system which has been implemented by the CP1600 CPU is illustrated in 
Figure 2-1. 

Observe that the CP1600 requires external logic to create its various timing and clock signals. 

Some bus interface logic is shown as absent because a number of devices must surround the CP1600; these in- 
clude: 

1) An address buffer, since data and addresses are multiplexed on a single 16-bit bus. 

2) Buffer amplifiers to provide the power required by the type of memory and I/O devices that will normally be con- 
nected to a CP1600 CPU. 

3) A one-of-eight decoder chip to create eight individual control signals out of three controls output by the CP1600. 

4) A one-of-sixteen multiplex chip to funnel sixteen external status signals into the CP1600 if using external 
branches. 
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Were you to compare Figure 2-1 with an equivalent figure for a low-end microprocessor such as the SC/MP (which is 
described in Chapter 3 of the Osborne 4 & 8-Bit Microprocessor Handbook (Osborne/McGraw-Hill. 1 980), the CP1600 
might appear to offer fewer logic functions; but within the functions it does provide, the CP1 600 provides considerably 
more logic and program execution capabilities. Where low-end microprocessors choose to condense, onto a single 
chip, simple implementations of different logic functions, high-end products such as the CP1600 choose to provide 
more devices — with greater capabilities on each device. 
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Figure 2 -1. Logic of the CP1600 CPU and CP1680 I/O Buffer 
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CP1600 PROGRAMMABLE REGISTERS 

The CP1600 has eight 16-bit programmable registers, which may be illustrated as follows: 
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The way in which the registers illustrated above are used is unusual when compared to other nnicrocomputers de- 
scribed in this book. All eight 16-bit registers can be addressed as though they were general purpose registers; 
however, only Register RO has no other assigned function. We may therefore look upon Register RO as the Primary Ac- 
cumulator for this CPU. 

Registers R1, R2, and R3 serve as general purpose registers, but may also be used as Data Counters. 

In addition to serving as general purpose registers, R4 and R5 may be used as auto-incrementing Data Counters. 
Memory reference instructions that identify Register R4 or R5 as holding the implied memory address will cause the 
contents of Register R4 or R5 to be incremented — after the memory reference instructions have completed execution. 

Registers R6 and R7, in addition to being accessible as general purpose registers, also serve as a Stack Pointer and a 
Program Counter, respectively. 

Having the Stack Pointer accessible as a general purpose register makes it quite simple to maintain more than one 
Stack in external memory; also, you can easily address the Stack as data memory using the Stack Pointer as a Data 
Counter. 

Having the Program Counter accessible as a general purpose register can be useful when executing various types of 
conditional branch logic. 

While having the Stack Pointer and the Program Counter accessible as though they were general purpose registers 
may appear strange, this is a feature of the PDP-1 1 minicomputer — and is a very powerful programming tool. 

CP1 600 MEMORY ADDRESSING MODE 

The CP1 600 addresses memory and I/O devices within a single address space. 

When referencing external memory, you can use direct addressing. Implied addressing, or implied addressing 
with auto-increment. 



CP1600 DIRECT 
ADDRESSING 



Direct addressing instructions are all two or more words long, where the second or last 
word of the instruction object code provides a 1 6-bit direct address. 

CP1600 direct addressing instructions are complicated by the fact that CP1600 program 

memory is frequently only 1 bits wide. That is to say, even though the CP1 600 is a 1 6-bit microprocessor, its instruc- 
tion object codes are only 10 bits wide. If program memory is only 10 bits wide, then direct addresses will only be 10 
bits wide. A 10-bit direct address will access the first 1024 words of memory only. 
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Were you to implement a 1 6-bit wide program memory, then you could directly address up to 65,536 words of memo- 
ry; however, six bits of the first object program word for every instruction in program memory would be wasted. This 
may be illustrated as follows: 
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Instructions that reference memory using implied addressing identify general purpose 
Register R1, R2, or R3 as containing the implied address. 

A memory reference instruction which identifies Register R4 or R5 as providing the external 
memory address will always cause Register R4 or R5 contents to be incremented following the 
memory access; thus you have implied memory addressing with auto-increment. 

Memory reference instructions that specify implied memory addressing via Register 1 , 2, 3, 4. or 5 can access 
8-bit memory. An SDBD instruction executed directly before a valid memory reference instruction forces the memory 
reference instruction to access memory one byte at a time. If implied memory addressing via Register 1, 2, or 3 is 
specified, then the same byte of memory will be accessed twice. For an instruction that loads the contents of data 
memory into Register RO, this may be illustrated as follows: 
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If Register R4 or R5 provides the implied memory address for the instruction which follows an SDBD instruction, then 
the implied memory address is incremented twice, and two sequential low-order bytes of data are accessed. For an in- 
struction which loads data into Register RO, this may be illustrated as follows: 



Memory 



RO I BB YY 




Program memory 
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Data memory 



The SDBD instruction may also precede an immediate instruction. Now the immediate data will be fetched from the 
low-order byte of the next two sequential program memory locations. This may be illustrated as follows: 

Memory 




Without the preceding SDBD instruction, an immediate instruction will access the next single program memory word 
to find the required immediate data. Ten or more bits of immediate data will be accessed, depending on the width of 
program memory words. 



The CP1600 has no Stack reference instructions such as a Push or Pull; rather, a variety of CP1600 
memory reference instructions can identify Register R6 as providing the implied address. STACK 

When Register R6 provides the implied address, it is treated as an upward migrating Stack ADDRESSING 
Pointer. When a memory write operation specifies Register R6 as providing the implied memory 
address. Register R6 contents will be incremented following the memory write. A memory read instruction that 
specifies Register R6 as providing the implied memory address will cause the contents of Register R6 to be decre- 
mented before the read operation occurs. 

An unusual feature of the CP1 600 is the fact that a variety of secondary memory reference instructions can also 
reference memory via the Stack Pointer. When these instructions are executed, Register R6 contents are decre- 
mented before the memory access occurs — as though a Pull operation from the Stack were being executed. 

Logically, Register R6, the Stack Pointer, is being handled as though it were a Data Counter with post-increment and 
pre-decrement. 
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Jump instructions use direct memory addressing. Jump instructions are all three words long. The direct address is 
computed from the second and third memory words as follows: 
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AAAAAABBBBBBBBBB Jump address (binary) 

yy are enable/disable bits for interrupts 

XX identify the register where the return address will be stored for JSR 

XX and yy are described In detail in Table 2-4. 

You can enable or disable interrupts whenever you execute a Jump or Jump-to-Subroutine instruction. 

The only difference between a Jump instruction and a Jump-to-Subroutine instruction is that the Jump-to-Subroutine 
instruction saves the Program Counter contents in Register 4, 5, or 6. The two high-order bits (xx) or the second Jump- 
to-Subroutine object code word specifies which of the three registers will be used to hold the return address. 

Jump-to-Subroutine instructions, like the Jump instruction, allow direct memory addressing only. 

CP1 600 STATUS AND CONTROL FLAGS 

The CP1 600 CPU has four of the standard status flags; in addition, it has some unusual control signals. 
These are the four standard status flags: 

Sign (S). This status is set equal to the high-order bit of any arithmetic operation result. 

Zero (Z). This status is set to 1 when any instruction's execution creates a zero result. The status is set to for a nonzero 
result. 

The Carry (C) and Overflow (0) statuses are standard carry and overflow, as described in Volume 1. 

Four control signals (EBCAO - EVCA3) are output during a Branch-on-External (BEXT) instruction. These four sig- 
nals are output to reflect the low-order four bits of the BEXT instruction's object code. External logic receives these four 
signals and (depending on their state), may or may not return a high input via EBCI. If EBCI is returned high, then the 
BEXT instruction will perform a branch; if EBCI is returned low. then the BEXT instruction will cause the next sequential 
instruction to be executed. The four control signals EBCAO - EBCA3 therefore provide the CP1 600 with a means of test- 
ing 16 external conditions. 

CP1600 CPU PINS AND SIGNALS 

CP1600 CPU pins and signals are illustrated in Figure 2-2. 

DO - D1 5 is a multiplexed Address and Data Bus. Given a total of 40 pins in a package, CP1 600 designers have been 
forced to share 16 pins between addresses and data. Three control signals, BDIR, BC1, and BC2, identify the traffic 
on the Address/Data Bus. External logic (one MSI chip) must decode these three signals to create eight control 
signals, as summarized in Table 2-1. 

Remaining signals may be divided into four groups: timing, status/control, interrupt, and DMA. 

Two timing clock signals are required: 4>1 and <I>2. These are complementary clock signals which may be illustrated 
as follows: 
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Figure 2-2. CP1600 CPU Signals and Pin Assignments 



MSYNC i s a some what unusual signal, as compared to other microcomputer clock signals in this boo k. Following 
powerup, MSYNC must be held low for at least 10 milliseconds. On the subsequent rising edge of MSYNC, logic inter- 
nal to the CP1600 CPU will synchronize the <I>1 and «I>2 clock signals to start a new machine cycle. Most of the CPU 
devices we have described in this book use a reset signal, or have internal powerup logic which performs this clock 
synchronization. 

Now consider the status and control signals. 

First of all, there are the four control outputs which we have already described: EBCAO - EBCA3. There is one con- 
ditional Branch instruction (BEXT) which will only branch if a high signal is input via EBCI. When the BEXT in- 
struction is executed, the low-order four BEXT instruction object code bits are output via EBCAO - EBCA3. External 
logic is supposed to decode these four signals by whatever means are appropriate — and thence determine whether 
EBCI should be input high or low. A high input, as we have just stated, will result in a branch; a low input will cause the 
next sequential instruction to be executed. 

In reality, there is no connection within CP1600 CPU logic between the EBCI input and the four EBCAO - EBCA3 out- 
puts. So far as external logic is concerned, the execution of a BEXT instruction is identified by signal levels output and 
maintained on the EBCAO - EBCA3 outputs, while the EBCI input determines whether a branch will or will not occur. 
How external logic chooses to determine whether EBCI will be set high or low is entirely up to external logic. The only 
vital function served by EBCAO - EBCA3 is to identify the instant at which a BEXT instruction is executed. 

Another unusual control signal provided by the CP1600 is PCIT; this is a bidirectional signal. When input low, this 
signal prevents the Program Counter from being incremented following an instruction fetch. This signal is also output 
as a low pulse following execution of a software interrupt instruction. Instruction timing separates the active input and 
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active output of this signal; providing external logic adheres to tinning requirements, a conflict between input and out- 
put logic will never arise. 



BDRDY is equivalent to the WAIT signal we have described for a number of other microcomputers. BDRDY is in- 
put low by any external logic which requires more time in order to re spond to an I/O access. Recall that the CP1600 
uses a single addr ess spac e to reference memory or I/O devices. The BDRDY signal causes the CPU to enter a Wait 
state for as long as BDRDY is being input low; however, during the Wait state CPU logic is not refreshed. Thus a Wait 
state cannot last for more than 40 microseconds, or the contents of internal CPU locations will be lost. 



STPST, a Halt/Reset input, is an edge-triggered signal. When external logic inputs a high-to-low transition via STPST, 
the CPU will complete execution of any interrupt instruction, then will enter a Halt state and output HALT high. If a 
non-interruptable instruction is being executed, then the Halt state will not being until completion of next interruptable 
instruction's execution. The Halt state will last until external logic inputs another high-to-low STPST transition, at 
which time the Halt output will be returned low and normal programming execution will continue. Execution of the 
HLT instruction also causes the CP1600 to enter a Halt state, as described above. 

Let us now look at interrupt signals. 



The CP1600 has two inte rrupt request inputs — INTR and INTRM. INTR has higher priority than INTRM. INTR can- 
not be disabled. Typically, INTR will be used to trigger an interrupt upon power failure or other catastrophes. 

The interrupt acknowledge signal is created by external logic which must decode the BC1, BC2, and BDIR sig- 
nals, as shown in Table 2-1. Observe that there are, in fact, two interrupt acknowledge signals: the first (INTAK) 
acknowledges the interrupt itself, while the second (DAB) is used as a strobe for external logic to return an interrupt ad- 
dress vector. The interrupt sequence is described later in this chapter. 

The CP1600 has two additional interrupt-related signals which are unusual when compared to other microcomputers 
described in this book. 

TCI is output high when an End-of-lnterrupt instruction is executed. This signal makes it easy for external logic to 
generate interrupt priorities which extend across the execution of an interrupt service routine. 



Table 2-1. CP1 600 Bus Control Signals 
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The CPU is inactive and the Data/Address Bus is in a high impe- 
dance state. 
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A memory address must be input to the CPU via the Data/Address 
Bus. 
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Acknowledged external interrupt requesting logic must place the 
starting address for the interrupt service routine on the Address Bus. 
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Data write strobe for external memory. 
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This signal identifies a time interval during which the Data/Address 
Bus is floated, while data input on the Data Bus is being interpreted 
as the effective memory address during a direct memory addressing 
operation. 
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The CPU is writing data into external memory. DW will precede 
DWS by one machine cycle. 
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DTB 


This is a read strobe which external memory or I/O logic can use in 
order to place data on the Data/Address Bus. 
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This is an interrupt acknowledge signal. It is followed by IAD which 
is a strobe telling the external logic which is being acknowledged to 
identify itself by placing an address vector on the Data/Address Bus. 
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Figure 2-3. CP1600 Machine Cycles and Bus Timing 
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Figure 2-4. CP1600 Instruction Fetch Timing 
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Figure 2-5. CP1600 Timing for Memory Read Instruction with Implied Memory Addressing 



CP1600 INSTRUCTION TIMING AND EXECUTION 

CP1600 instructions are executed as a sequence of machine cycles. Each machine cycle has four clock periods, 
as illustrated in Figure 2-3. Machine cycles are identified by their cycle number and by the levels of the BC1, BC2, 
and BDIR signals. Each of the eight level combinations is given a name, taken from Table 2-1 . This name becomes the 
name of the machine cycle. Thus in Figure 2-4, and in subsequent instruction timing illustrations, each machine cy- 
cle is identified by a signal name from Table 2-1. 

Figure 2-3 shows general case timing for data output or input on the Data/Address Bus. In between data input or out- 
put operations the bus is floated. 

CP1600 MEMORY ACCESS TIMING 

Figure 2-4 illustrates instruction fetch timing for a CP1600 instruction's execution. Three machine cycles are re- 
quired. During the first machine cycle an address is output. Nothing happens during the second machine cycle; it is a 
"time spacing" machine cycle that routinely separates two CP1 600 Bus access machine cycles. The object code for the 
accessed instruction is returned during the third machine cycle. 

Figure 2-5 illustrates timing for the simplest memory read instruction's execution. In this case the data memory 
address is taken from one of the CPU registers. There is no difference between timing for the three machine cycles of an 
instruction fetch or a data memory read. As illustrated in Figure 2-5, a simple memory read instruction's execution 
consists of two three-machine cycle memory read operations, separated by a spacing no operation machine cycle. 
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Figure 2-6. CP1600 Timing for Memory Write Instruction with Implied Memory Addressing 

Figure 2-6 illustrates timing for a simple CP1600 memory write instruction execution. Data is output for two 
machine cycles, giving external logic ample time to respond to the data output. External logic uses the DWS machine 
cycle as a write strobe. 

Any memory reference instruction that specifies direct memory addressing will require one three-clock-period machine 
cycle to fetch each word of the instruction object code; an NACT clock period will separate each machine cycle. After 
the first instruction fetch machine cycle, an ADAR-NACT clock period combination will be inserted in the second (and 
third, if present) instruction fetch machine cycle. During an ADAR clock period, BC1 is high, while BC2 and BDIR are 
low. No other control signals are active. Thus, for a two-word memory read or memory write instruction that 
specifies direct addressing, the following clock periods and machine cycles will be required for instruction ex- 
ecution: 



Direct Addressing 
Memory Read 
Machine Cycles 



Direct Addressing 

Memory Write 
Machine Cycle 



BAR ) 
NACT>" 
DTB j 



NACT' 



Fetch first Instruction 
— object code word — 



-Spacing machine cycle- 



BAR 

NACT 

DTB 

•NACT 



NACT--* 

BAR \ 
NACTV 
DTB J 



-Fetch second instruction- 
object code word 



-Spacing machine cycle - 



Memory read 
-machine cycle 



Memory write 
machine cycle - 




^NACT 

{BAR 
NACT 
DW 
DWS 
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BAR 
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NACT 




NACT 



DTB 



BC1 



BC2 



BDIR 



J 



BDRDY 





Figure 2-7. CP1600 Wait State Timing 

THE CP1 600 WAIT STATE 

The CP1600has a Wait state equivalent to those desc ribed for other microcomputers in this booic. External logic that 
requires more time to respond to an access must input BDRDY low before the end of the BAR machine cycle, during 
which an address is output and the device is selected. Timing is illustrated in Figure 2-7. 

If you examine Figures 2-4, 2-5 and 2-6, you will see that an address is output during a BAR machine cycle to initi- 
ate any external device access. The BAR machine cycle is always foll owed by an NACT machine cycle; in the middle of 
T1 during this NACT machine cycle, the CP1 600 samples BDRDY. If BDRDY is low, the n a seque nce of NACT machine 
cycles o ccurs. In the middle of T4 for every NACT machine cycle, the CP1600 samples BDRDY again. Upon detecting 
BDRDY high, the CP1600 resumes instruction execution with a DTB machine cycle. 

A Wait state must last for less than 40 microseconds, since the CP1600 is a dynamic device. 

THE CPl 600 HALT STATE 

The CPl 600 has a Halt state which may follow execution of the Halt instruction, or may be initiated by external 
logic. 

When the Halt instruction is executed, then, following the instruction fetch machine cycle, the HALT signal is output 
high and a sequence of NACT machine cycles is executed. 

External logic initiates a Halt state by making the STPST input undergo a high-to-low transition. Following execution of 
the next interruptable instruction, a Halt state begins. The HALT signal is output high and a sequence of NACT 
machine cycles is executed. 

A Halt state, whether it is initiated by execution of a Halt instruction or by a high-to-low transition of STPST, must be 
terminated by a high-to-low transition of STPST. This will cause the Halt state to end at the conclusion of the next 
NACT machine cycle. Timing for a Halt state which is initiated and terminated by STPST may be illustrated as follows: 



STPST 



HALT 




Next interruptable 

instruction's 

execution 

ends here 



/ 



Y 

HALT STATE 




Next NACT machine 
cycle ends here 
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The PCIT sign al as a n input inhibits CP1600 Program Counter increment logic. Thus, external 
logic can input PCIT low — in which c ase th e same instruction will be continuously re-executed 
until PCIT go es hig h ag ain. Ho wever, PCIT should only change levels while the CPU has been 
halted. Thus, PCIT and STPST should be used together as follows: 



CP1600 

PCIT 

SIGNAL 



PCIT REQUEST 



STPST 



PCIT 





CP1600 INITIALIZATION SEQUENCE 



The CP1600 is initialized by inputting the MSYNC signal low for a minimum of 10 milliseconds after power is 
first applied to the CPU. 

MSYNC must make a low-to-high transition, marking the end of the initialization, on a rising edge of the <I>1 clock sig- 
nal. On the next rising edge of 01, instruction execution will begin. This may be illustrated as follows: 

I'll' 
I I I I 

I T1 T2 I T3 I T4 j 

I I II I 




When instruction execution begins, interrupts are disabled. The following sequence of machine cycles is executed: 

■ Read Data /Address Bus and load into Program Counter 



NACT 

lAB-^ 

NACT 

NACT 

NACT 

BAR<^ 

NACT 

DTB 

etc 



■ Output Program Counter contents to fetch first instruction 



During the lAB machine cycle, external logic must supply a 1 6-bit address at DO - D1 5. Your external logic must pro- 
vide this address, which in the simplest case may be 0000 by grounding the bus, orFFFFig by tying itto-FBV following 
a startup. 

The address which is input at lAB is output at BAR, initiating program execution. 

CP1 600 DMA LOGIC 

CP1600 DMA logic is quite standard. When external logic wishes to transfer data under DMA control, it inputs 
BUSRQ low. At the conclusion of the next interruptable instruction's execution, the CPU floats the 
Data/Ad dress Bus and enters a Wait state, during which a sequence of NACT machine cycles is executed. 
BUSAK is output low at the beginning of the first NACT machine cycle. 

The NACT machine cycles that occur during a DMA operation refresh the CPU. NACT machine cycles that occur 
during a Wait state do not refresh the CPU. This means that any number of NACT machine cycles can occur during a 
DMA break, while a Wait state must be shorter than 40 microseconds. 



The DMA break ends when ext ernal logic inputs BUSRQ high again. BUSRQ is sampled during T1 of ev ery DMA NACT 
machine cycle. When BUSRQ is sampled high, two additional NACT machine cycles are executed, then BUSAK is out- 
put high and normal program execution resumes. 

DMA timing is illustrated in Figure 2-8. 
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Figure 2-8. CP1 600 DMA Timing 
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Figure 2-9. CP1600 Interrupt Service Routine Initialization 
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INSTRUCTION FETCH 



BAR 
MCI 
I I 
Ti!t2«T3!T4 



NACT 
MC2 



INSTRUCTION EXECUTE/FETCH 
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address out 
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Figure 2-10. CP1600 Timing for TCI Instruction's Execution 

THE CP1600 INTERRUPT LOGIC 

The CP1600 uses a vectored interrupt processing system. 

External logic requests an interrupt by inputting a low signal at either the INTR or INTRM pins. 

Following the execution of the next interruptable instruction, the CP1600 acknowledges the interrupt by pushing 
Register R7 contents (the Program Counter) onto the Stack; then the CP1600 outputs 111, followed by 010 at BC1, 
BC2, and BDIR. External logic must respond by placing 16 bits of data on the Data/Address Bus. These 16 bits of data 
will be loaded into Register R7, the Program Counter, thus causing program execution to branch to an interrupt service 
routine dedicated to the interrupt. Timing is illustrated in Figure 2-9. 



The PCIT signal is output low following execution of a software interrupt instruction (SIN). This is the only microcom- 
puter described in this book which allows external logic to respond to a software interrupt in this fashion. Allowing ex- 
ternal logic to respond to a software interrupt only makes sense when you anticipate your product being used in a 
minicomputer-like environment. Typically, the software interru pt will interface to logic of a front panel or console. 
When an SIN instruction is executed, a one-machine cycle low PCIT pulse is output. 

You may, if you wish, end an interrupt service routine by executing a Terminate Current Interrupt (TCI) instruction, in 
which case the TCI signal will be output high. 

Timing for TCI is given in Figure 2-10. 

Following an interrupt acknowledge, the interrupt service routine must execute instructions in order to disable inter- 
rupts and save the contents of registers on the Stack. The exception is Register R7, the Program Counter, which is auto- 
matically pushed onto the Stack following an interrupt acknowledge. 

External logic is entirely responsible for any type of interrupt priority arbitration which may occur, and for the genera- 
tion of the interrupt vector address which must be input following an interrupt acknowledge. 
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It is quite easy to generate signals equivalent to other microcomputer system busses from the CP1600 System Bus. 
Therefore, you can use parts described in Volume 3 to handle CP1600 interrupt requirements. 

THE CP1 600 INSTRUCTION SET 

The CP1 600 instruction set is relatively straightforward. Addressing modes, which we have already described, are sim- 
ple, and instructions are typical of those we have seen and described for other microcomputers. Unusual features relat- 
ing to addressing modes available with individual instructions are summarized in Table 2-2, which describes the 
CP1600 instruction set. 

If you have never programmed a PDP-11 minicomputer, then you should pay particular attention to program- 
ming techniques that result from the Stack Pointer and Program Counter being accessed as general purpose 
registers. 

A wide variety of Register Operate instructions allow you to compute data and load the result directly into Register R7, 
the Program Counter. In effect, these become computed Jump instructions. 

The ability to manipulate Register R6, the Stack Pointer, as though it were a general purpose register means that it is 
easy to maintain a number of different Stacks in external read/write memory. 

The Jump-to-Subroutine instruction has a minicomputer flavor to it. Rather than saving the return address on the 
Stack, Register R7 contents are moved to General Purpose Register R4 or R5. A number of minicomputers will save a 
subroutine return address in a general purpose register in this fashion. The problem with this logic is that you must ex- 
ecute an additional instruction within the subroutine to save the return address on the Stack if you are going to use 
nesting subroutines. If you are passing subroutine parameters, however, this is an excellent arrangement, for the Jump- 
to-Subroutine instruction places the address of the parameter list directly in a Data Counter with auto-increment We 
have described the concept of parameter passing in Volume 1, Chapter 7. 

Note that the CP1600 instruction set lacks a logical OR. 

In Tables 2-2 and 2-4, instruction length is given in terms of "words" rather than "bytes", as we have done in pre- 
vious chapters. Since only the lower 10 bits of theCP1600 object code are presently used, system configurations need 
not have the full 16-bit word size. Hence a "word" may be 10 to 16 bits wide, depending on the implementation. 

The following notation is used in Table 2-2: 

ADDR One word of direct address 

cond Condition on which a branch may be taken. Table 1-3 lists all 14 branch conditions. 

DATA One word of immediate data. 

DISP One word displacement. See Table 2-4 for location of sign bit. 

E External branch condition. 

EBCAO-3 The external branch condition address lines: EBCAO, EBCA1, EBCA2, and EBCA3. 

EBCI The external branch condition input line. 

LABEL A 16-bit direct address, target of a Jump instruction. See Table 2-4 for the bit format. 

PCIT The software interrupt output line. 

RB General Purpose Register R4, R5, or R6. 

RD One of the general purpose registers, used as a destination for operation results. 

RM One of the general purpose registers used as a Data Counter, R4 or R5, if specified, is auto-incremented 

after the memory access. R6 is incremented after a write, and decremented before a read. 
RR General Purpose Register RO, R1, R2, or R3. 

RS One of the general purpose registers, used as the source of an operand. 

Statuses: 

S the Sign status 

C the Carry status 

Z the Zero status 

the Overflow status 

The following symbols are used in the STATUSES column: 

X the status flag is affected by the operation 
a blank means the status flag is not affected 

the operation clears the status flag 

1 the operation sets the flag 

2 the Overflow flag is affected only on 2-bit shifts or rotates 



2-16 



SW The Status Word, whose bits correspond to the condition of the status flags in the following way: 

3 2 10 < Bit No 
JS| z|o|C| Status Word 

When the status word is copied into a register, it goes to the upper half of each byte: 




tRR] [SW] 

When the status word is loaded from a register, it connes from the upper half of the lower byte: 



E 



E 




[RSI 



[SW] 



x<y,z> Bits y through z of the Register x. For example, R7<15,8> represents the upper byte of the Program 

Counter 
(,2) Indicates that the operand ",2" is optional 

A low pulse 
[ ] Contents of location enclosed within brackets. If a register designation is enclosed within the brackets, 

then the designated register's contents are specified. If a memory address is enclosed within the brackets, 

then the contents of the addressed memory location are specified. 
[[ ]] Implied memory addressing: the contents of the memory location designated by the contents of a register. 

A Logical AND 

-V- Logical Exclusive-OR 

± Addition or subtraction of a displacement, depending on the sign bit in the object code. 

*— Data is transferred in the direction of the arrow. 
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Table 2-2. CP1600 Instruction Set Sumnriary 



TYPE 


MNEMONIC 


OPERAND(S) 


WORDS 


STATUSES 


OPERATION PERFORMED 


S Z C 


PRIMARY I/O 

AND MEMORY 

REFERENCE 


MVI 
MVI® 
MVO 
MVG® 


ADDR.RD 
RM.RD 

RS,ADDR 
RS.FtM 


2 

1 
2 

1 




[RD]^[ADDR] 

Load register from memory, using direct addressing. 
[RDl-ECRM]] 

Load register from memory, using implied addressing. 
[ADDR]— [RS] 

Store register to memory, using direct addressing. 
[[RM]]-[RS] 

Stbre register to memory, using implied addressing. If RS=R4. R5. R6 or R7. then RS=RM is not 

supported. 


lU 

U 

z 

lU 

ce 

Ul 

u. 

lU 

oc 

> 
oe 
O 

s 

lU 

s 

Q 
Z 
< 

< 
o 

M 


ADD 

ADD® 
SUB 

SUB® 
CMP 

CMP® 

AND 
AND® 
XOR 

XOR® 


ADDR.RD 
RM.Rb 

ADDR.RD 
RM,RD 

ADDR.RS 

RM.RS 

ADDR.RD 
RM.RD 

ADDR.RD 
RM.RD 


2 
1 
2 

1 
2 

1 

2 

1 
2 
1 


XXX X 
XXX X 
XXX X 
XXX X 
XXX X 

XXX X 

X X 
X X 
X X 
X X 


tRD]— [RD]+ [ADDR] 

Add memory contents to register, using direct addressing. 
[RD]— [RD]+ [[RM]] 

Add hnemory contents to register, using implied addressing. 
[RD] — [RD]- [ADDR] 

Subtract memory Contents from register, using direct addressing. 
[RD]— [RD]- [[RM]] 

Subtract memory contents from register, using implied addressing. 
[RS]- [ADDR] 

Cdmpare memory contents with registers. uSing direct addressing. Only the status flags are 

affected. 
[RS]- [[RM]] 

Compare memory contents with register's, using implied addressing. Only the status flags are 

affected. 
[RD]-[RD] A[ADDR] 

AND memory contents with those of register, using direct addressing. 
tRD]-[RD] A [[RM]] 

AND memory contents with those of register, using implied addressing. 
[RD]— [RD]V-[ADDR] 

Eicclusive-OR memory contents with those of register, using direct addressing. 
[RD]-[RD]V-[[RM]] 

Exclusive-OR memory contents with those of register, using implied addressing. 



Table 2-2. CP1600 Instruction Set Summary (Continued) 



TYPE 


MNEMONIC 


OPERAND(S) 


WORDS 


STATUSES 


OPERATION PERFORMED 


S Z C 


< 
a 

lU 

S 
S 


MVII 
MVOI 


DATA,RD 
RS.DATA 


2 
2 




[RDl— DATA 

Load immediate to specified register. 
[[R7]+1]-[RS] 

Store contents of specified register in immediate field of MVOI Instruction. This is only possible if 

program memory is read /write memory (rather than ROM). 


lU 

H 

111 

Q. 

o 

III 

1- 
< 
5 

Ul 

S 
S 


ADbl 
SUBI 
CMPI 
ANDI 
XORI 


DATA,RD 
DATA.RD 
DATA.RS 
DATA.RD 
DATA,RD 


2 
2 
2 
2 
2 


XXX X 
XXX X 
XXX X 
X X 
X X 


[RD]— [RDl + DATA 

Add immediate to specified register. 
[RD]— [RDl-DATA 

Subtract immediate data from specified register. 
[RDl-DATA 

Compare immediate data with contents of specified register. Only the status flags are affected. 
[RD]-[RD] ADATA 

AND immediate data with contents of specified register. 
[RD]— [RDl-VDATA 

Exclusive-OR immediate data with contents of specified register. 


a. 

s 

-> 


J 

JR 
JSR 

B 


LABEL 

RS 

RB.LABEL 

DISP 


3 

1 
3 
2 


X X 


[R7]- LABEL 

Jump to given address. 
[R7]-[RS] 

Jump to address contained in specified register. 
[RB] — [R7]; [R7]— LABEL 

Jump to given address, saving Program Counter in R4, R5, or R6. 
[R7]-[R7] + 2±DISP 

Branch relative to Program Counter contents. 


5 1 

<i 

g 8 


Bcond 
BEXT 


DISP 
DISP.E 


2 
2 




If cond is true, [R7]— [R71 + 2+DISP 

Branch relative on given condition; otherwise, execute next sequential instruction. 
EBCA0-3-E; 
If EBCI = 1, [R7] — [R7] + 2±DISP 

Branch relative if external condition is true. 



Table 2-2. CP1600 Instruction Set Sunnmary (Continued) 



TYPE 


MNEMONIC 


OPERAND(S) 


WORDS 


STATUSES 


OPERATION PERFORMED 


S Z C 







MOVR 


RS.RD 




X X 




[RD]— [RS] 




M 


ADDR 


RS.RD 




XXX 


X 


Move contents of source register to destination register. 
[RD]— [RS]+[RD] 






SUBR 


RS.RD 




XXX 


X 


Add contents of specified registers. 
[RD]— [RDl- [RS] 






CMPR 


RS.RD 




XXX 


X 


Subtract contents of source register from those of destination register. 
[RD]-[RS] 






ANDR 


RS.RO 




X X 




Compare registers' contents. Only the status flags are affected. 
[RD]-[RD]A[RS] 




« s 


XORR 


RS.RD 




X X 




AND contents of specified registers. 
[RD]— [RD1V-[RS] 
Exclusive-OR contents of specified registers. 






CLRR 


RD 




1 




[RD]— [RD]V[RD] 






TSTR 


RS 




X X 




Clear specified register. 
[RS]— [RS] 






INCR 


RD 




X X 




Test contents of specified register. 
[RD]— [RD] + 1 




i 


DECR 


RD 




X X 




Increment contents of specified register. 
[RDl-[RD]-1 




& 


COMR 


RD 




X X 




Decrement contents of specified register. 
[RDl-[RD] 




i 


NEGR 


RD 




XXX 


X 


Complement contents of specified register (ones complement). 
[RD]-[RD] + 1 




!£ 


ADCR 


RD 




XXX 


X 


Negate contents of specified register (twos complement). 
[RD]-[RD]+[C] 






SLL 


RR(,2) 




X X 




Add Carry bit to specified register contents. 




|15 < oV#— 

[RR] 
Shift logical left one or two bits, clearing bit (and bit 1 if shifting twice). 



Table 2-2. CP1600 Instruction Set Summary (Continued) 



TYPE 


MNEMONIC 


OPERAND(S) 


WORDS 


STATUSES 


OPERATION PERFORMED 


S Z C O 


O 
111 

Z 
Z 

o 
o 

iU 
IU 

a. 
o 

K 
111 
H 
M 

5 
IU 


RLC 

sue 

SLR 
SAR 

RRC 
SARC 

SWAP 


RR(,2) 
RR(,2) 

RR(,2) 
RR(,2) 

RR(.2) 
RR(,2) 

RR(.2) 


1 
1 

1 

1 

1 

1 

1 


XXX 2 
XXX 2 

X X 
X X 

XXX 2 
XXX 2 

X X 




"■■ 


M c W 1 o 1 V^i5 •< oW-i 

^ [RR] 
Rotate left one bit through Carry, or rotate 2 bits left through Overflow and Carry. 




^ ^ [RR] 
Shift logical left one bit into Carry, clearing bit 0, or shift left two bits into Overflow and Carry, 
clearing bits and 1 . 


0-~»4l5 " » o| 


[RR] 
Shift logical right one or two bits, clearing bit 15 (and bit 14 if shifting twice). 






Shift arithmetic right one or two bits, copying high order bit. 




UHo|}>(c|-»^i5 ►ol-J 

^ [RR] 
Rotate right one bit through Carry, or rotate, two bits right through Overflow and Carry. 


•— — ' [RR] 

Shift arithmetic right one bit into Carry,, or two bits into Overflow and Carry. 


pi 817 01 [RR] 
Swap bytes of register once, or twice. 



Table 2-2. CP1600 Instruction Set Summary (Continued) 



TYPE 


MNEMONIC 


OPERAND(S) 


WORDS 


STATUSES 


OPERATION PERFORMED 


S Z 


i 

w 


PSHR 
PULR 


RS 
RD 


1 
1 




Separate mnemonics for MVO® RS,R6. 
Separate mnemonics for MVI@R6,RD. 


H 
Z 


SIN 

EIS 

DIS 

TCI 

JE 

JD 
JSRE 
JSRD 


(2) 

LABEL 

LABEL 

RB.LABEL 

RB.LABEL 


1 

1 
1 
1 
3 
3 
3 
3 




pciT— i_r 

Software interrupt. 
Enable interrupt syetem. 
Disable interrupt system. 
Terminate current interrupt. 

Jump to given address and enable inten-upt system. 
Jump to given address and disable interrupt system. 

Jump to given address, saving Program Counter in R4, R5 or R6, and enable interrupt system. 
Jump to given address, saving Program Counter in R4, R5 or R6, and disable interrupt system. 


(0 

3 


GSWD 

RSWD 
CLRC 
SETC 


RD 
RS 


1 

1 
1 
1 


XXX X 



1 


[RD<;15,12>]— (SWl; [RD<7,4>]— [SW] 

Place Status Word in upper half of each byte of the specified register. RD may be RO, R1, R2 or 

R3. 
[SW] — [RS<7,4>] 

Load Status Word from bits 7 through 4 of the specified register. 
[C]-0 

Clear Carry. 
[Cl-1 

Set Carry. 




NOPP 
NOP 
HLT 

SDBD 


(2) 


2 

1 

1 
1 




No Operation. 

Halt after executing next instruction. 

Set double byte data mode for next instruction, which must be of one of the following types: 

Primary or secondary I/O or memory reference 

Immediate or immediate operate 
If implied addressing through R 1 , R2, or R3 is used, the same byte will be accessed twice; address- 
ing through R4, R5, or R7 will give bytes from the addressed location and that addressed after 
auto-increment. Direct addressing and Stack addressing are not allowed in double byte mode. 



Table 2-3. CP1600 Branch Conditions and Corresponding Codes 







OBJECT CODE 


MNEMONIC 


BRANCH CONDITION 


DESIGNATION 


C 


= 1 


0001 


LGT 


Cairy 

(logical greater than) 




NC 


C=0 


1001 


IXT 


No Cany 
(logical less than) 




OV 


= 1 
Overflow 


0010 


NOV 


0=0 

No overflow 


1010 


PL 


S=0 
Plus 


0011 


Ml 


S = 1 
Minus 


1011 


ZE 


Z = 1 


0100 


EQ 


Zero (equal) 




NZE 


Z=0 


1100 


NEQ 


Nonzero (not equal) 




LT 


SVO = 1 
Less than 


0101 


GE 


SVO=0 

Greater than or equal 


1101 


LE 


ZV{SV0) = 1 
Less than or equal 


0110 


6T 


ZV(SVO) = 
Greater than 


1110 


use 


CVS = 1 

Unequal sign and carry 


0111 


ESC 


CVS=0 

Equal sign and carry 


1111 



bb 



cccc 
ddd 



The following notation is used in Table 2-4: 

Where ten digits are shown, they are the ten low-order bits of a 10 to 16-bit word. (Word size depends on the system 
implementation.) Where four digits are shown, they represent the hexadecimal notation for an entire word (10 to 16 
bits). 

Two bits indicating one of the first three general purpose registers: 

00 = RO 

01 =R1 
10 = R2 

Four bits giving the branch condition, as shown in Table 2-3. 
Three bits indicating a destination register, RD: 

000 = RO 

001 = R1 
010 = R2 
Oil =R3 

100 = R4 

101 =R5 

110 = R6 

111 = R7 
Four bits giving the external branch condition, E. Control signals EBCA0-EBCA3 reflect the state of these four 
bits. 
One word of immediate data (10 or 16 bits) 
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mmm Three bits indicating a Data Counter Register RM: 

000 = RO 

001 =R1 
010 = R2 
Oil =R3 

1 00 = R4 

101 =R5 

110 = R6 

111 = R7 

m One bit indicating the number of rotates or shifts: 

one bit position 

1 two bit positions 

p One bit of imnnediate address 

P One hexadecimal digit (4 bits) of immediate address 

rr Two bits indicating one of the first four general purpose registers: 

00 = R0 

01 =R1 

10 = R2 

11 =R3 

sss Three bits indicating a source register, RS: 

000 = RO 

001 =R1 
010 = R2 
Oil =R3 

100 = R4 

101 =R5 

110 = R6 

1 1 1 = R7 

z Sign of the displacement: 

add the displacement to PC contents 

1 subtract the displacement from PC contents 

In the "Machine Cycles" column, when two numbers are given with one slash between them (e.g., 7/9), execution time 
depends on whether or not a branch is taken. When two numbers are given, separated by two slashes (such as 8//1 1), 
execution time depends on which register contains the implied address. 



THE BENCHMARK PROGRAM 

For the CP1600 our benchmark program may be illustrated as follows: 

LOAD THE I/O BUFFER STARTING ADDRESS INTO R4 
LOAD THE TABLE STARTING ADDRESS INTO R1 
LOAD ADDRESS OF FIRST FREE TABLE WORD INTO R5 
LOAD WORD COUNT INTO R2 
LOOP MVI@ R4,R0 LOAD NEXT DATA WORD FROM lOBUF 

STORE IN NEXT TABLE WORD 
DECREMENT WORD COUNT 
RETURN IF NOT END 
RETURN ADDRESS OF NEXT FREE TABLE BYTE 

This benchmark program makes very few assumptions. The input table lOBUF and the data table TABLE can have any 
length, and can reside anywhere in memory. The address of the first free word in TABLE is stored in the first word of the 
TABLE. 



MVII 


I0BUF,R4 


MVII 


TABLE.RI 


MVI@ 


R1,R5 


MVII 


CNT,R2 


MVI@ 


R4,R0 


MVO@ 


R0,R5 


DECR 


R2 


BNZE 


LOOP 


MVO@ 


R5,R1 
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Table 2-4. CP1600 Instruction Set Object Codes 









MACHINE 


INSTRUCTION 


OBJECT CODE 


WORDS 


CYCLES 


ADCR RD 


OOOOIOIddd 


1 


6 


ADD ADDR.RD 


101 lOOOddd 
PPPP 


2 


10 


ADD® RM.RD 


lOllmmmddd 


1 


8//11 


ADDI DATA,RD 


lOnniddd 

nil 


2 


8 


ADDR RS.RD 


001 Isssddd 


1 


6 


AND ADDR.RD 


mOOOOddd 
PPPP 


2 


10 


AND® RM.RD 


mOmmmddd 


1 


8// 11 


ANDI DATA,RD 


moillddd 

nil 


2 


8 


ANDR RS.RD 


01 lOsssddd 


1 


6 


B DISP 


lOOOzOOOOO 
PPPP 


2 


7/9 


Bcond DISP 


lOOOzOcccc 
PPPP 


2 


7/9 


BEXT DISP.E 


lOOOzleeee 
PPPP 


2 


7/9 


CLRC 


0006 


1 


4 


CLRR RD 


Ollldddddd 


1 


6 


CMP ADDR.RS 


IIOIOOOsss 
PPPP 


2 


10 


CMP® RM.RS 


llOlmmmsss 


1 


8//11 


CMPI DATA.RS 


1101111SSS 

nil 


2 


8 


CMPR RS.RD 


OlOlsssddd 


1 


6 


COMR RD 


000001 Iddd 


1 


6 


DECR RD 


OOOOOIOddd 


1 


6 


DIS 


0003 


1 


4 


EIS 


0002 


1 


4 


GSWD RR 


00001 lOOrr 


1 


6 


HLT 


0000 


1 


4 


INCR RD 


000000 Iddd 


1 


6 


J LABEL 


0004 

llppppppOO 

PPPP 


3 


12 


JD LABEL 


0004 

llppppppIO 

PPPP 


3 


12 


JE LABEL 


0004 

llppppppOl 

PPPP 


3 


12 


JR RS 


OOlOssslll 


1 


7 


JSR RB.LABEL 


0004 

bbppppppOO 

PPPP 


3 


12 


JSRD RB.LABEL 


0004 

bbppppppIO 

PPPP 


3 


12 









MACHINE 


INSTRUCTION 


OBJECT CODE 


WORDS 


CYCLES 


JSRE RB.LABEL 


0004 

bbppppppOl 

PPPP 


3 


12 


MOVR RS.RD 


OOlOsssddd 


1 


6//7 


MVI ADDR.RD 


lOIOOOOddd 
PPPP 


2 


10 


MVI' RM.RD 


lOIOmmmddd 


1 


8//11 


MVn DATA.RD 


101011 Iddd 
ill! 


2 


8 


MVO RS.ADDR 


lOOIOOOsss 
PPPP 


2 


11 


MVG® RS.RM 


lOOImmmsss 


1 


9 


MVOI RS.DATA 


1001111SSS 

nil 


2 


9 


NEGR RD 


OOOOIOOddd 


1 


8 


NOP (2) 


000011010m 


1 


6 


NOPP 


lOOOzOIOOO 
PPPP 


2 


7 


PSHR RS 


loomosss 


1 


9 


PULR RD 


10101 lOddd 


1 


11 


RLC RR(.2) 


OOOIOIOmrr 


1 


6/8 


RRC RR(.2) 


OOOmOmrr 


1 


6/8 


RSWD RS 


00001 llsss 


1 


6 


SAR RR(.2) 


0001 101 mrr 


1 


6/a 


SARC RR(.2) 


OOOmimrr 


1 


6/8 


SDBD 


0001 


1 


4 


SETC 


0007 


1 


4 


SIN (2) 


000011011m 


1 


6 


SLL RR(,2) 


OOOIOOImrr 


1 


6/8 


SLLC RR(.2) 


OOOIOIImrr 


1 


6/8 


SLR RR(.2) 


0001 lOOmrr 


1 


6/8 


SUB ADDR.RD 


llOOOOOddd 
PPPP 


2 


10 


SUB® RM.RD 


1 lOOmmmddd 


1 


8//11 


SUBT DATA.RD 


1 1001 1 Iddd 

nil 


2 


8 


SUBR RS.RD 


OlOOsssddd 


1 


6 


SWAP RR(,2) 


OOOIOOOnrr 


1 


6/8 


TCI 


0005 


1 


4 


TSTR RS 


OOlOssssss 


1 


6//7 


XOR ADDR.RD 


nnOOOddd 
PPPP 


2 


10 


XOR® RM.RD 


inimmmddd 


1 


8// 11 


XORI DATA.RD 


111111 Iddd 

nil 


2 


8 


XORR RS.RD 


Oil Isssddd 


1 


6 
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Figure 2-11. CP1600 to 8080A Bus Conversion 
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SUPPORT DEVICES THAT MAY BE USED WITH THE CP1600 

r-v v^r I uKjyj rTiiCrOCOrnpu iGr SyStGrn VVitii Sny SiyninCant CSpauiiitiSS will US6 support Cl6VIC6S ot somG otnGr 

microprocessor. Parallel I/O capability is available with the CP1680, (described next), but priority interrupt logic, DMA 
logic, and serial 1/0 logic, to mention just a few common options, may need additional support devices. Fortunately, it 
is quite easy to generate an 8080A-compatible system bus from the CP1 600 system bus. Logic is illustrated in 
Figure 2-11. 

The CP1600A is the fastest version of the CP1600 CPU: it runs with a 500 nanosecond machine cycle. The CP1600 
machine cycle is equivalent to an 8080A clock period. Since the standard 8080A clock period is also 500 nanoseconds, 
no speed conflicts will arise. 

The bus-to-bus interface logic illustrated in Figure 2-11 is self-evident, with the exception of bus demultiplexing logic. 
The CP1600 Data/Address Bus is shown buffered by a demultiplexing buffer that is connected to two latched buffers. 
One of the latched buffers accepts the demultiplexer outputs only when a valid address is being output, as identified by 
BAR high. The second latched buffer may be a bidirectional latched buffer, or it may be two unidirectional latched 
buffers. Three latching strobes are required: DTB, lAB, and DWS. 

DTB and lAB are data input strobes. DTB strobes data input that is to be interpreted as data, while lAB stroves data in- 
put that is to be interpreted as an address. So far as external logic is concerned, both of these signals are simple data in- 
put strobes. We could therefore generate a single data input strobe as the OR of DTB and lAB. When this data input 
strobe is high, information on the 8080A System Bus side of the latched data buffer must be input to the buffer: this 
data must simultaneously be transmitted to the multiplexer 

DWS is the data output strobe. When high, this signal must strobe data from the multiplexer to the latched data buffer: 
this latched data must immediately appear at the 8080A System Bus side of the latched data buffer. 

Since the CP1 600 uses a 1 6-bit Data Bus, you will probably have to generate two external device data busses: a high- 
order byte bus and a low-order byte bus. All external devices that transmit or receive parallel data must be present in 
duplicate. For example, were 8255 parallel interface devices to be present, the following connections would be re- 
quired: 



DO •• D7 

If u 



PA high 
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PC high 




8255 
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The CP1600 and MC6800 system busses are singularly incompatible. You should not attempt to use MC6800 support 
devices with the CP1 600. 




Pin Name 

DO- D7 
PDO - PD15 
BDIR , BC1, BC2 
CK1 

cr 

PE 

AR 

INTRQ 

TCI 

IMSKI 

IMSKO 

ERRO R 

PCLR 

vcc- Vdd. gnd 



Description 

CPU Data /Address Bus 

Peripheral I/O Port 

Bus Control signals 

Clock signal 

Chip Enable 

I/O handshake control 

I/O handshake control 

Interrupt request 

Terminate current interrupt 

Daisy chain priority 

Daisy chain priority 

Error interrupt request 

Reset 

Power, Ground 



Type 

Bidirectional, tristate 

Bidirectional 

Input 

Input 

Input 

Output 

Input 

Output 

Input 

Input 

Output 

Input 

Input 



Figure 2-12. CP1680 JOB Signals and Pin Assignments 
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Figure 2-13. A CP1600-CP1680 Microcomputer Configuration 



THE CP1680 INPUT/OUTPUT BUFFER (lOB) 

The CP1680 lOB is a parallel I/O device designed specifically for the CP1600 CPU. This device provides a single 
1 6-blt parallel I/O port, which may optionally be configured as two 8-bit I/O ports. Primitive handshaking control 
signals are available with the parallel I/O logic. Elementary interval timer and prioritized interrupt logic is also 
provided. 

Figure 2-1 also illustrates that part of our general microcomputer system logic which has been implemented on 
theCPieao lOB. 

The CP1 600 lOB is packaged as a 40-pin DIP. It requires two power supplies, +5V and -1-1 2V. All inputs are TTL com- 
patible. The device is implemented using N-channel MOS technology. 

Figure 2-13 illustrates a CP1600 microcomputer system with three CP1680 lOB devices in the configuration. 

CP1680 lOB PINS AND SIGNALS 

The CP1680 lOB pins and signals are illustrated in Figure 2-12. We will summarize these signals and the func- 
tions they serve before examining device operations in detail. 

Let us begin by looking at the interface between the CP1680 lOB and the CP1600 CPU. 

DO - D7 provide an 8-bit parallel Data/Address Bus via which all communications between the CPU and lOB oc- 
cur. This bus must connect to the low-order eight bits of the 16-bit CPU Data/Address Bus. 

The three bus control signals, BC1, BC2, and BDIR, connect the CP1 680 to the CP1600 as illustrated in Figure 
2-13. The CP1680 lOB decodes these three bus control signals internally. 

A clock input is required by the CP1680. This clock input (CK1) is used by internal logic to determine when BC1, 
BC2, and BDIR are valid. CK1 must have the following wave form: 




CK1 



CK1 must be derived from the CP1600 clock signals by external logic. 

Let us now look at the interface between external logic and the CP1680 lOB. 

PDO - PD15 provide a 16-bit parallel I/O port which can optionally be configured as 



CP1600 I/O 
PORT PIN 
CHARACTERISTICS 



two 8-bit I/O ports. While PDO - PD15 are in theory bidirectional, these pins are more ac- 
curately described as pseudo-bidirectional. This is because when a zero has been written 
to one of these pins, the output can sink 1.6 mA for an output voltage of -t-0.5V. External 
logic will have a hard time overcoming this sink in order to pull the pin high. In contrast, when a 1 is written to one of 
these pins, the output sources just 1 OO/aA at +5V. External logic will have little problem sinking 1 0OjuA in order to pull 
a pin low. Therefore, you should output a 1 to any pin that is subsequently to receive input data. External logic will then 
leave the pin high when inputting 1, while pulling the pin low to input 0. 

The handshaking control signals whichjink the CP1680 lOB with external logic are PE and AR. PE is a control signal 
which is output by the CP1680, and AR is a control signal which is input to the CP1680. 

Now consider CP1 680 interrupt signals. 

An interrupt request is transmitted to the C P160 CPU via INTRO. The CPU acknowledges the interrupt via the 
INTAK combination of BDIR, BC1, and BC2. TCI must be output low by the C PU at the end of the interrupt ser- 
vice routine. This signal is required by CP1680 interrupt logic, which uses the low TCI pulse in its priority arbitration, 
as described later in this chapter 
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Interrupts may be generated by conditions internal to tlieCP1680, or by a low input at ERROR. The ERROR input is 
reserved for error conditions detected by external logic. 

IMSKI and IMSKO are Interrupt priority input and interrupt priority output signals, respectively. These signals are 
used to generate daisy chain interrupt priorities between CP1680 106 devices, as illustrated in Figure 2-13. We will 
describe CP1680 interrupt priorities in nnore detail later in this chapter. 

MCLR is the master reset control input for the CP1680. This signal nnust be input low for at least 10 milliseconds in 
order to reset the CP1680 lOB. 

CP1 680 ADDRESSABLE REGISTERS 

The CP1680 has eight addressable locations, which may be illustrated as follows: 



DO - D7 



<:=^ 



Control 



C=^ 



Data, low 



^ 



Timer, low 



C 'y Timer, high 



0=^ 



I/O interrupt 
vector 



c=c> 



Timer interrupt 
vector 



K Error interrupt 

i/ vector 



C=^ 



(, ^ Data, high |<^ 



^ 



PDO - PD15 



These eight addressable locations are all 8-bit registers; they are addressed using the first eight addresses in a 256-ad- 
dress block, as follows: 

Register Address 

Control 

Data buffer, low-order byte 1 

Data buffer, high-order byte 2 

Tinner, low-order byte 3 

Timer, high-order byte 4 

I/O interrupt vector 5 

Timer interrupt vector 6 

Error interrupt vector 7 
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The actual 256 addresses will be identified by the eight high-order CP 160 Data/Address Bus lines, which will be used 
to create CP1680 device select logic. This device select logic creates CE (the chip enable signal); it may be illustrated 
as follows; 

DO 

• 
D7 

D8 

• 

D15 



.^ u 


^> 
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-^- < F 
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r \ 
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xxxxxxxx 

causes CE 

low 


1 
[ 


f 

7 at CP1680 



xxxxxxxx 



OOOOOY Y Y 



T 



Valid CP1680 addresses 



May be 000, 001, 010, Oil, 100, 101, 110, 111 



-J May have any 8- bit pattern that device select logic 
' has been designed to create CE low in response to. 



THE CP1 680 CONTROL REGISTER 

We will summarize the individual bits of the CP1680 control register before describing the operations they control. 
Here are CP1680 Control register bit assignments: 



-Bit No. 

• CP1680 Control register 



This is called the 



i - Parallel I/O active ) _ ... 

! 1 - Parallel I/O inactive) at S^ 
PE=Ready 

ERROR input signal level held here 

[ - PD0-PD15 configured as two 8-bit ports 
I 1 - PD0-PD15 configured as one 16-bit port 

\ - Disable parallel I/O and Error Interrupts 
[ 1 - Enable parallel I/O and Error interrupts 

i - Disable timer interrupts 
[ 1 - Enable timer interrupts 

fO - Disable clock logic 
1 - Enable clock logic 



Parity of D8-D15 byte 
Parity of D0-D7 byte 



I;: 



= even parity 
odd parity 
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Bit is always the complement of the PE control output. This bit may be interrogated by the CPU. If parallel data 
transfer interrupts are disabled, this allows the GPU to poll on status when monitoring parallel data transfers. PE signal 
levels are illustrated in Figures 2-14 and 2-15. 



Bit 1 reflects the level of the ERROR input. If parallel data transfer interrupt logic is disabled, then the Error interrupt 
logic is also disabled, thus, the CPU must also examine the Error status bit when polling the CP1680. 

Bit 2 determines whether PDO - PD1 5 will act as a single 1 6-bit I/O port, or as two 8-bit I/O ports. This is only important 
when outputting data. 

Control register bits 3 and 4 are used to enable and disable parallel data transfer and Error interrupt logic, and timer in- 
terrupt logic. 

Control register bit 5 is used to enable and disable CP1680 interval timer logic, if this bit is 0. the interval timer will not 
decrement. 

Bits 6 and 7 report the parity of the high-order byte and low-order byte for data that is input or output via PDO - PD1 5. 
indicates even parity while 1 indicates odd parity. 

All Control register bits may be written into or read. You should be very careful when setting or resetting individual bits 
not to simultaneously modify other Control register bits. This means you should use a three-instruction sequence with 
an AND or OR mask to set or reset any Control register bit. For details see Volume 1, Basic Concepts. 

CP1 680 DATA TRANSFER OPERATIONS 

The CPU inputs and outputs data via the CP1680 iOB by executing iVIVi and MVO instructions, respectively. 

The CPU must access the CP1680 in byte mode, since an 8-bit Oata/Address Bus (DO - D7) connects the CPU and the 
CP1 680 IOB. Whether the I/O port PDO - PD1 5 is configured as a single 1 6-bit port or as two 8-bit ports has no bearing 
on the fact that the CPU must access the CP1680 in byte mode. 

The most efficient way of accessing the CP1680 is by using the SDBD instruction with implied memory ad- 
dressing. Consider data input. If PDO - PD15 is configured as two 8-bit I/O ports and you wish to access just one of 
these I/O ports, then you can use implied memory addressing via R1 , R2, or R3. We may illustrate input from the high- 
order byte of I/O Port PD8 - PD15 as follows: 
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If PDO - PD15 are configured as two 8-bit 1/0 ports or as a single 16-bit I/O port, and you want to read both I/O ports, 
then you should use the SDBD instruction with innplied memory addressing via R4 or R5. This may be illustrated as 
follows: 



RO 
R4 



3A 4F 



2E 01 



T_J 



CP1600 
CPU 



Z 



DO- D7 



"^X? 



^ 



D8 - D15 



^_. 




2E 
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CE=0 



=!^ 



=Cx^ 



5 



> 



Register 01 



4F 



Register 02 



3A 



CE 



PDO - PD7 

lO 



PD8 - PD15 



Control register bit 2 configures PDO - PD15 as a single 16-bit I/O port or as two 8-bit I/O ports. 

Given the fact that MVI and MVO instructions (in byte mode) should be used to access the CP1 680, when should these 
accesses occur? 

The answer is that the PE and AR signals control event sequences. 

Consider parallel data input, as illustrated in Figure 2-14. 



RE 




AR 



INTRQ 



INTAK 



When the CPU is ready to input data in resets the 
Control register READY bit low. This forces the PE 
output high — _^___^^_ 

External logic uses PE high to trigger data transfer 
to the PD1680. External logic signals the end of 
data input by inputting AR" low 





Figure 2-14. PD1680 Handshaking with Data Input 
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When the CPU is ready to receive data, it resets Control register bit to 0; this forces the PE control signal high. 

When external logic senses PE high, it must transnnit data to the PDO - PD15 I/O port. At this point it makes no 
difference whether pins have been configured as two 8-bit ports or as a single 16-bit port. External logic will pull to 
ground selected high pin s, w hile leaving other high pins alone. When external logic has completed data input, it sig- 
nals the fact by inputting AR low. It is the high-to-low transition of the AR control input which indicates the presence of 
new data for the CPU to read. When AR" makes its high-to-low transition, PE also makes a high-t o-low t ransition, and 
Control register bit is set to 1 . If interrupts have been enabled , then an interrupt is requested via INTRQ. Figure 2-14 
assumes that interrupts have been enabled; therefore INTRQ is shown making a high-to-low transition. 

The CPU will acknowledge the interrupt request, as described earlier in this chapter, by outputting INTAK via BC1, 
BC2, and BDIR. Logic internal to the CP1680 uses INTAK to reset INTRQ high again. 

There are many ways in whic h external logic can determine when toset AR high again. In Figure 2-14 we show exter- 
nal logic using PE to set ^IT high. Clearly, when PE makes a low-to-high transition, the CPU must have acknowledged 
AR low; therefore external logic can now set AR high. Now that A R is high again, external logic can input new data. An 
alternative scheme would be for externa! logic to constantly hold AR low. using the level of the PE output to determine 
when new data could be transmitted. When PE is high, external logic will transmit new data to the CP1680 once. As 
soon as it transmits new data, external logic will strobe the data with a short, high AR pulse, then wait for PE to go low 
and high again before inputting more data. This may be illustrated as follows: 
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CPU ready 
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for input 
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ready 


logic Inputs 


again 
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Data output handshaking is illustrated in Figure 2-15. 



DO - D7 



PE 




When CPU outputs data, PE is automatically set 
high 

External logic uses PE high as a "valid data ready" 
signal. After reading this data it resets AR low 



AR 



UTrG 



INTAk 




Figure 2-15. PD1680 Handshaking for Data Output 
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The most important point to note is that there is no control bit which specifies data input mode or data output 
mode. Thus, the signal sequences we described for data input and those we are about to describe for data out- 
put occur automatically; the input or output mode is purely a function of CPU and external logic interpretation. 

Whenever the CPU outputs data to the PD1680, the arrival of data forces RE output high. If PDO - PD15 has been con- 
figured as two 8-bit ports, then the arrival of a single data byte to either port will cause PE to be output high, if PDO - 
PD15 is configured as a single 16-bit I/O port, then PD will not be output high until two bytes of data have been 
received from the CPU by the PD1680. 

Once PE is output high, nothing more happens until external logic responds. External logic cannot tell by the simple in- 
spection of any control signals whether a data input operation or a data output operation is in progress. It is up to you. 
when designing your system, to dedicate CP1680 devices to input or output; or you must generate your own identifica- 
tion logic in the event that a CP1680 lOB is bidirectional. In Figure 2-15 we simply assume that external logic knows 
data is to be read, and knows whether the data is 1 6 bits or 8 bits wide. Furthermore, if the data is 8 bits wide, external 
logic must know which 8 bits to read, in any event, when external logic has completed its undefined operations, it must 
input ^ lo w. The h igh-to-low transition of A?? forces PE low again, and if interrupts are enabled, an interrupt will be re- 
quested via iNTRQ. When the CPU ac knowle dges the interrupt by outputting INTAK via BC1, BC2, and BDIR, the 
PD1680 uses the INTAK pulse to reset INTRQ high. 

The method used by external logic to reset AR high again is undefined, in Figure 2-15, we show PE going high as the 
trigger which external logic uses to reset ^R" high. This is clearly a viable scheme; PE will not go high again until fresh 
data has been output, at which point it is safe to ass ume that the CPU knows prior data has been read by external logic. 
It would be equally viable for external logic to hold AR continuously low. transmitting a short, high pulse whenever it 
reads data. This may be illustrated as follows: 
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Because there are no control signals which identify the PD1680 operating in input mode or output mode, there 
is no straightforward scheme for handling bidirectional data transfers with a single PD1 680 device. 

THE CP1680 INTERVAL TIMER 

The CP1680 has very elementary interval timer logic. A 1 6-bit Timer register, addressed as two separate 8-bit loca- 
tions, decrements once every eight CK1 pulses, providing the timer has been enabled. You enable and disable timer 
logic via Control register bit 5. As a separate event, timer interrupts may be disabled via Control register bit 4. If timer 
interrupts are enabled, then when the timer decrements to 0, an interrupt request will occur. (Timer interrupt logic is 
described with other CP1680 interrupt logic later in this chapter.) If timer interrupts are not enabled, then the timer it- 
self is effectively disabled, since you cannot test any timer status flag to see if the timer timed out; nor can you ac- 
curately read the contents of the Timer registers on the fly, since there is no protection against reading timer contents 
while it is in the process of being decremented. 

The only timer programmable option you have is to load an initial value before the timer is enabled. The timer 
has no buffer; therefore, once it times out it begins decrementing again, if still enabled, beginning with the 
value FFFFig. This may be illustrated as follows: 
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The only accurate long time intervals you can compute are exact multiples of FFFF15 ♦ 8 ♦ CK1. 

The CP1600A uses a 4MHz two-phase clock, which generates a 500 nanosecond cycle time. Thus, CK1 equals 5O0 
nanoseconds, and long CP1600A time intervals must be an exact multiple of 262.144 milliseconds — the time it will 
take for the counter to decrement from ffff-\Q to 0000. 

The CP1 600 uses a 3.3MHz two-phase clock, which generates a 600 nanosecond cycle time; therefore, long time inter- 
vals must be exact multiples of 314.572 milliseconds. 

The CP1 61 0, which runs on a 2MHz two-phase clock and has a one microsecond cycle tinne, will compute long time in- 
tervals that are exact multiples of 524.288 milliseconds. 

You cannot attempt to generate clock periods that are multiples of shorter time intervals by loading some initial value 
into the timer following each time out; an unknown amount of time will elapse between the interval timer interrupt oc- 
curring and being acknowledged. The length of this unknown period of time will depend on the number of non-inter- 
ruptable instructions which may be executing in sequence when the interrupt request first occurs, plus any higher 
priority interrupts which may exist. Therefore, if you load an initial value into the timer, it should be to compute an isol- 
ated time interval only. Here is an appropriate instruction sequence: 

INPUT CONTROL REGISTER CONTENTS 

ZERO BITS 4 AND 5 

RETURN TO CONTROL REGISTER 

TRANSMIT LOW-ORDER TIMER 

INITIAL BYTE 

TRANSMIT HIGH-ORDER TIMER 

INITIAL BYTE 

LOAD PRIOR CONTROL REGISTER CONTENTS 

SET BITS 4 AND 5 

START TIMER 

The instruction sequence above begins with three instructions that load the CP1680 Control register contents into 
Register RO. Bits 4 and 5 are zeroed, then the result is returned to the Control register. Thus, the timer and timer inter- 
rupts are disabled. We do not bother with an SDBD instruction. Since the data source is eight bits wide, only the low- 
order byte of Register RO will be significant. This being the case, we can use an 8-bit immediate AND mask to modify 
Register RO contents before returning the low-order byte to the Control register. 

Next, we load the initial timer value, one byte at a time, into Register RO. Each byte is written out to the appropriate half 
of the Control register. Once again we do not need to use the SDBD instruction. Since an 8-bit data path connects the 
CPU to the 1680 lOB, only the low-order byte of Register RO will be significant during the data output. 

Finally, we start the timer by loading Control register contents into Register RO, setting bits 4 and 5 to 1 and writing 
back the result. 

When you write into the Timer registers, you clear any timer interrupt requests which may at that time be pending. 
CP1680 INTERRUPT LOGIC 



MVI 


IOB,R0 


ANDI 


CFH,R0 


MVO 


RO.IOB 


MVII 


2AH.R0 
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R0,IOB+3 


MVII 


34H,R0 


MVO 
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MVI 
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30H,R0 


MVO 
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A CP1 680 lOB will generate an interrupt request by outputting a low signal at INTRQ if any one of these three 
conditions occurs: 



1) A low input at ERROR. External logic can request an interrupt via the CP1680 using the ERROR input. 

2) The A^ handshaking control input makes a high-to-low transition. This is illustrated in Figures 2-14 and 2-15. 

3) The Interval Timer decrements from 1 to 0. 

Recall that there are two separate interrupt enable/disable control bits in the Control regi ster. On e control bit applies to 
the Interval Timer, while the other control bit applies to both the^ handshaking and ERROR interrupts. 

Interrupt priorities among the three sources within a single CP1680 lOB are as follows: 



ERROR highest 

AR handshaking 

Timer lowest 

When more than one CP1880 lOB is present in a CP1600 microcomputer system, then daisy chain priority is im- 
plemented using the MSKI input signal and the MSKO output signal. Signal connections are illustrated in Figure 
2-13. The manner in which interrupt priorities are handled by the CP1680 is a little unusual. 

Two or mo re CP168 devices may combine their interrupt request signals, which are wired ORed and input to the 
CPieOOvia INTRQ. The CP1 600 acknowledges an interrupt via the INTAK combination of BC1, BC2, and BDIR. We de- 
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scribed this process earlier in the chapter. All CP1680 devices simultaneously receive the INTAK combination: 
however, a CP1680 which is acknowledged raises its IMSKO signal high, causing it to become the IMSKI input to the 
next CP1680 in the daisy chain. Any device that receives a high IMSKI input ignores the interrupt acknowledge. Thus, 
only the highest priority, interrupt requesting CP1 680 device in the daisy chain will process the interrupt acknowledge. 
However, it takes a finite amount of time for IMSKO high signals to propagate as IMSKI signals, and thus ripple through 
the daisy chain. Consequently, a maximum of eight CP1 680 devices may be present in the daisy chain. A ninth device 
will receive its IMSKI high signal too late and will respond to an interrupt acknowledge. 

CP1 680 lOB devices maintain their interrupt priority status until they receive a high TCI pulse. At that time, prior inter- 
rupt priorities are reset at all devices, and new priority arbitration begi ns. T hus, when using CP1 680 lOB devices, you 
are required to end ait interrupt service routines by executing a TCI instruction. 

Note that if one CP1680 lOB has more than one active interrupt request (for example, an ERROR interrupt request and a 
timer interrupt request), then this internal interrupt priority will take precedence over the daisy chain interrupt priority. 
That is to say, the ERROR interrupt request will be acknowledged and serviced first. After the next TCI instruction is ex- 
ecuted, the timer interrupt request will be serviced before any interrupt request from a lower priority CP1680 device is 
acknowledged. 

Every CP1 680 device has three 8-bit Interrupt Vector registers, one dedicated to each of the three interrupt 
sources. These three Interrupt Vector registers were illustrated earlier in the chapter. Following an interrupt 
acknowledge, when the lAB combination appears at BC1, BC2, and BDIR, the contents of the Interrupt Vector 
register for the highest priority active interrupt will be returned to the CPU. Interrupt acknowledge timing is il- 
lustrated in Figure 2-9. At the interrupt service location a Jump-to-Subroutine instruction will probably be stored. 
Since the Jump-to-Subroutine object code is three words long, a maximum of 85 interrupts can be origined in the first 
256 words of memory. This is more than sufficient, since only eight CP1680 devices with 24 interrupts can be sup- 
ported in a single daisy chain. 
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DATA SHEETS 

This section contains specific electrical and timing data for the following devices; 

• CP1600CPU 
.CP1600ACPU 

• CP1610CPU 

. IOB1680 I/O Buffer 
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Data sheets on pages 2-D2 through 2-D6 reprinted by permission of General Instrument Corporation. 



2-D2 



CP1600 



ELECTRICAL CHARACTERISTICS (CP1600) 
Maximum Ratings* 

Vdd, Vcc, GND and all other input/output voltages 



'Exceeding these ratings could cause 
permanent damage to these devices. 
Functional operation at these conditions is 
not implied— operating conditions are 
specified below. 

Standard Conditions: (unless otherwise noted) 

Vdd=+12V±5%. 70mA(typ) , 110mA(max.) Vbb= -3V±10%. 0.2mA(typ) , 2mA(max.) 

Vcc=+5V±5%, 12mA(typ) , 25mA(max.) Operating Temperature (Ta)=0°C to +70° C 



with respect to Vbb -0.3V to +18.0V 

Storage Temperature -55° C to +150° C 

Operating Temperature .0°Cto+70°C 



Cliaracterlstic 


Sym 


MIn 


Typ" 


Max 


UniU 


Conditions 


DC CHARACTERISTICS 
















Clock Inputs 
















High 


V,„c 


10.4 


- 


Vdd 


V 






Low 


V,LC 





- 


0.6 


V 






Logic Inputs 
















Low 


ViL 





- 


0.65 


V 






High (All Lines except BDRDY) 


v,„ 


2.4 


- 


Vcc 


V 






High (Bus Data Ready Line 
















See Note) 


V,„B 


3.0 


- 


Vcc 


V 






Logic Outputs 








. 








High 


VoH 


2.4 


Vtt 


— 


V 


Ioh = 100mA 




Low (Data Bus Lines DO-D15) 


Vol 


- 


- 


0.5 


V 


loL= 1.6mA 




Low (Bus Control Lines, 
















BC1,BC2,BDIR) 


Vol 


- 


- 


0.45 


V 


loL = 2.0mA 




Low (All Others) 


Vol 


- 


- 


0.45 


V 


loL = 1.6mA 




AC CHARACTERISTICS 
















Clock Pulse Inputs, <t>^ or <^2 
















Pulse Width 


t02, t</)2 


120 




- 


ns 






Sl<ew(<^1.<^2 delay) 


tl2,t21 





- 


- 


ns 






Clo'ck Period 


tcy 


0.3 


- 


2.0 


MS 






Rise & Fall Times 


tr.tf 


- 


- 


15 


ns 






Master SYNC: 
















Delay from </> 


tms 


- 


- 


30 


ns 






0O-D1S Bus Signals 
















Output delay from <)>^ 
















(float to output) 


tec 


- 


- 


120 


ns 


1 TTL Load & 25 pF 




Output delay from (f>2 


















(output to float) 


tBF 


- 


50 


- 


ns 








Input setup time before (^l 


tBl 





- 


- 


ns 








Input hold time after <^1 


'b2 


10 


- 


- 


ns 








Sua Control Signals 


















BC1,BC2,BDIR 


















Output delay from 01 


»DC 


- 


- 


120 


ns 








BUSAK Output delay from <t>A 


* BU 


- 


150 


- 


ns 








TGI Output delay from <t>^ 


tTO 


- 


200 


- 


ns 








TCI Pulse Width 


*TW 


- 


300 


- 


ns 








EBCA output delay from BEXT 


















input 


toE 


- 


- 


150 


ns 








EBCA wait time for EBCI input 


tAI 


- 


- 


400 


ns 


' 






CAPACITANCE 












TA = +25° C; Vdd = +12V; Vcc = 
Vbb = -3V; t«1 t</C = 120ns 


= +5V; 


01, 4>2 Clock Input capacitance 


C<t>^.c<t>2 


— 


20 


30 


PF 






Input Capacitance 
















D0-D15 


GIN 


— 


6 


12 


PF 






All Other 


— 


— 


5 


10 


pF 






Output Capacitance 
















DO-D15 in high impedance state 


Gd 


— 


8 


15 


pF 







**Typical values are at +25°C and nominal voltages. 

NOTE. 

The Bus Data ReaDY(BDRDY) line is sampled during time period TSI after a BAR or ADAR bus control signal. BDRDY must 
go low requesting a wait State 50 ns before the end of TSI and remain low for 50 ns minimum. BDRDY may go high 
asynchronously. In response to BDRDY, the CPU will extend bus cycles by adding additional microcycles up to a maximum 
of 40 Msec duration. 
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CP1 600A 

ELECTRICAL CHARACTERISTICS (CP1600A) 
Maximum Ratings* 

Vdd, Vcc, GND and all other Input/output voltages 

with respect to Vbb -0.3V to +18.0V 

Storage Temperature -SS'C to+150°C 

Operating Temperature 0°Cto+70°C 



'Exceeding these ratings could cause 
permanent damage to these devices. 
Functional operation at these conditions is 
not implied— operating conditions are 
specified below. 



Standard Conditions: (unless otherwise noted) 

Vdd=+12V+5%, 70mA(typ) , 140mA(max.) Vbb= -3V±10%, 0.2mA(typ) , 2mA(max.) 

Vcc=+5V±5%, 12mA(typ) , 25mA(max.) Operating Temperature (Ta)=0''C to +70° C 



Characteristic 


Sym 


Mln 


Typ" 


Max 


Unite 


Conditions 


DC CHARACTERISTICS 
















Clock Inputs 
















High 


V,HC 


10.4 


- 


Vdd 


V 






Low 


V,LC 





- 


0.6 


V 






Logic Inputs 
















Low 


V,L 





- 


0.65 


V 






High (All Lines except BDRDY) 


V,H 


2.4 


- 


Vcc 


V 






High (Bus Data Ready Line 
















See Note) 


V,HB 


3.0 


- 


Vcc 


V 






Logic Outputs 
















High 


VOH 


2.4 


Vcc 




V 


Ioh = 100mA 




Low (Data Bus Lines D0-D15) 


Vol 


- 


- 


0.5 


V 


loL= 1.6mA 




Low (Bus Control Lines, 
















BC1,BC2,BDIR) 


Vol 


- 


- 


0.45 


V 


Iol = 2.0mA 




Low (All Others) 


Vol 


- 


- 


0.45 


V 


loL= 1.6mA 




AC CHARACTERISTICS 
















Clock Pulse InpuU, 01 or 02 
















Pulse Width 


t02, 102 


95 




- 


ns 






Skew (01, 02 delay) 


tl2,t21 





-- 


- 


ns 






Clo'ck Period 


tcy 


0.25 


- 


2.0 


MS 






Rise & Fall Times 


tr, tf 


- 


- 


15 


ns 






Master SYNC: 
















Delay from 


tms 


- 


- 


30 


ns 






DO-D15 Bus Signals 
















Output delay from 01 
















(float to output) 


teo 


- 


- 


95 


ns 


1 TTL Load & 25 pF 




Output delay from 02 


















(output to float) 


tBF 


- 


50 


- 


ns 








Input setup time before 01 


tBI 





- 


- 


ns 








Input hold time after 01 


tB2 


10 


- 


- 


ns 








Bus Control Signals 


















BC1,BC2,BDIR 


















Output delay from 01 


toe 


- 


- 


200 


ns 








BUSAK Output delay from 01 


' BU 


- 


150 


- 


ns 








TCI Output delay from 01 


tTO 


- 


200 


- 


ns 








TCI Pulse Width 


'tw 


- 


300 


- 


ns 








EBCA output delay from BEXT 


















input 


toE 


- 


- 


150 


ns 








EBCA wait time for EBCI input 


tAI 


- 


- 


400 


ns 


1 


' 




CAPACITANCE 












TA = +25°C; Vdd = +12V; Vcc 
Vbb = -3V; 1 01 t 02 = 120ns 


= +5V; 


01, 02 Clock Input capacitance 


C01,C02 


— 


20 


30 


PF 






Input Capacitance 
















DO-D15 


CIN 


— 


6 


12 


pF 






All Other 


— 


— 


5 


10 


pF 






Output Capacitance 
















DO-D15 in high impedance state 


Cd 


— 


8 


15 


pF 







"Typical values are at +25°C and nominal voltages. 

NOTE: 

The Bus Data ReaDY(BDRDY) line is sampled during time period TSI after a BAR or ADAR bus control signal. BDRDY must 
go low requesting a wait state 50 ns before the end of TSI and remain low for 50 ns minimum. BDRDY may go high 
asynchronously. In response to BDRDY, the CPU will extend bus cycles by adding additional microcycles up to a maximum 
of 40 Msec duration. 
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CP1610 



ELECTRICAL CHARACTERISTICS (CP1610) 

Maximum Ratings* 

Vdd, Vcc, GND and all other Input/output voltages 

with respect to Vbb -0.3V to +18.0V 

Storage Temperature -55°C to+150°C 

Operating Temperature 0°Cto+70°C 



'Exceeding these ratings could cause 
permanent damage to these devices. 
Functional operation at these conditions is 
not implied— operating conditions are 
specified below. 



Standard Conditions: (unless otherwise noted) 

Vdd=+1 1 V±5%. 70mA(typ) , 1 1 0mA(max.) Vbb= -3V±10%, 0.2mA(typ) . 2mA(max.) 

Vcc=+5V±5%, 12mA(typ) , 25mA(max.) Operating Temperature (Ta)=0°C to +70°C 



Characteristic 


Sym 


MIn 


Typ** 


Max 


Units 


Conditions 


DC CHARACTERISTICS 
















Clock Inputs 
















High 


Vmc 


10.0 


- 


Vdd 


V 






Low 


V,LC 





- 


0.6 


V 






Input current 


_ 





— 


15 


mA 


Vmc = Vdd -1 




Logic Inputs 
















Low 


V,L 





- 


0.65 


V 






High (All Lines except BDRDY) 


V,H 


2.4 


- 


Vcc 


V 






High (Bus Data Ready Line 








• 








See Note) 


V,HB 


3.0 


- 


Vcc 


V 






Logic Outputs 
















High 


VoH 


2.4 


Vcc 


— 


V 


loH = 100M 




Low (Data Bus Lines DO-D15) 


Vol 


- 


- 


0.5 


V 


loL= 1.6mA 




Low (Bus Control Lines, 
















BC1,BC2,BDIR) 


Vol 


- 


- 


0.45 


V 


Iol = 2.0mA 




Low (All Others) 


Vol 


- 


- 


0.45 


V 


loL= 1.6mA 




AC CHARACTERISTICS 
















Clock Pulse Inputs, <t>^ or <t>2 
















Pulse Width 


t02, t02 


250 




- 


ns 






Skew(4>1, 02 delay) 


tl2, *21 





- 


- 


ns 






Clock Period 


tcy 


0.5 


- 


.2.0 


MS 






Rise & Fall Times 


tr,tf 


- 


- 


15 


ns 






Master SYNC: 
















Delay from 


tms 


- 


- 


30 


ns 






D0-D1S Bus Signals 
















Output delay from <^1 
















(float to output) 


tec 


- 


- 


200 


ns 


1 TTL Load & 25 pF 




Output delay from <t>2 


















(output to float) 


tBF 


- 


50 


- 


ns 








Input setup time before <^>^ 


tBI 





- 


- 


ns 








Input hold time after 01 


*B2 


10 


- 


- 


ns 








Bus Control Signals 


















BC1,BC2,BDIR 


















Output delay from <f>^ 


toe 


- 


- 


200 


ns 








BUSAK Output delay from 01 


* BU 


- 


150 


- 


ns 








TCI Output delay from 01 


tTO 


- 


200 


- 


ns 








TCI Pulse Width 


•tw 


- 


300 


- 


ns 








EBCA output delay from BEXT 


















input 


toE 


- 


- 


150 


ns 




' 




EBCA wait time for EBCI input 


tAI 


- 


- 


400 


ns 


\ 






CAPACITANCE 












TA = +25°C; Vdd = +12V; Vcc = 
Vbb = -3V; 1 01 t 02 = 120ns 


= +5V; 


01, 02 Clock Input capacitance 


C01 , C02 


— 


20 


30 


PF 






Input Capacitance 
















D0-D15 


CIN 


— 


6 


12 


PF 






All Other 


— 


— 


5 


10 


P"" 






Output Capacitance 
















DO-D15 in high impedance state 


Cd 


— 


8 


15 


pF 







"Typical values are at +25°C and nominal voltages. 

NOTE: 

The Bus Data ReaDY(BDRDY) line is sampled during time period TSI after a BAR or ADAR bus control signal. BDRDY must 
go low requesting a wait state 50 ns before the end of TBI and remain low for 50 ns minimum. BDRDY may go high 
asynchronously. In response to BOROY, the CPU will extend bus cycles by adding additional microcycles up to a maximum 
of 40Msec duration. 
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IOB1680 

ELECTRICAL CHARACTERISTICS 
Maximum Ratings* 

Vdd and Vcc and all other input/output voltages 

with respectto GND -0.3Vto+18V 

Storage Temperature -55°Cto+150°C 

Operating Temperature 0°Cto+70°C 

Standard Conditions (unless otherwise noted) 

All voltages referenced to GND 

Vdd = +12V ±5% 

Vcc = +5V ±5% 

Operating Temperature (Ta) = 0°C to +70° C 



'Exceeding these ratings could cause 
permanent damage. Functional operation of 
this device at these conditions is not 
implied — operating ranges are specified 
below. 



Characteristic 


Symbol 


MIn 


Typ" 


Max 


Unit 


Condition 


DC CHARACTERISTICS 














Clock Input: High 


Viho 


2.4 


- 


Vdd 


V 




Low 


Viic 





- 


.5 


V 




Logic Inputs: High 


Vih 


2.4 


— 


Vcc 


V 




Low 


Vi, 





— 


.65 


V 




Logic Outputs: High 


Voh 


2.4 


Vcc 


- 


V 


'oh = 100^A 


Low 


Vo, 


- 


- 


.5 


V 


Iqi = 1.6mA 


AC CHARACTERISTICS 














Clock Inputs 














OKI Clock period 


tfJC 


0.4 


- 


4.0 


us 




Clock width 


tcl 


70 


— 


— 


ns 




Rise & Fall times 


tcr.tcf 


- 


- 


10 


ns 




CAPACITANCE (Ta = 25° C, 














VoD = +12V, 














Vcc = +5V) 














Input Capacitance: D0-D7 


Cin 


- 


6 


12 


PF 


Vin = OV 


All others 




- 


5 


10 


PF 


Vin = OV 


Output Capacitance: 


Cout 


- 


8 


15 


pF 





**Typical values are at +25° C and nominal voltages. 



TIMING DIAGRAM 
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Note: CK1* not drawn to scale. 



CIRCUIT DESCRIPTION 

This circuit is designed to provide all the data buffering and 
control functions required when interfacing the Series 1600 
Microprocessor System to a simple peripheral device. Data is 
transferred to and from the peripheral on 16 bidirectional lines, 
each of which can be considered to be an input or output. The 
transfer of information with the CP1 600 is accomplished via an 8- 
bit highway, the 16-bits being transferred as two 8^bit bytes, the 
register addresses are assigned CP1600 memory locations, as 
follows (N is an arbitrary starting address): 



Register Address Description 

N Control Register 

N + 1 Data Register Low Order 8-bits 

N + 2 Data Register High Order 8-bits 

N + 3 Timer Low Order 8-bits 

N + 4 Timer High Order 8-bits 

N + 5 Peripheral Interrupt Address Vector 

N + 6 Timer Interrupt Address Vector 

N + 7 Error Interrupt Address Vector 
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Chapter 3 
THE TEXAS INSTRUMENTS TMS 9900, 
TMS 9980, AND TMS 9940 PRODUCTS 

The TMS 9900 was the first 16-bit microprocessor that could compete effectively in the minicomputer market. In fact, 
the TMS 9900 is a one-chip implementation of the TIVI 990 series minicomputer Central Processing Units. 

The TMS 9900 is packaged as a 64-pin DIP; it generates signals for a 1 5-bit Address Bus and a separate 1 6-bit Data 
Bus, whereas other 16-bit microprocessors multiplex their Data and Address Busses. The TMS 9980 series 
microprocessors are 40-pin DIP versions of the TMS 9900; in order to reduce pin counts, the TMS 9980 series 
microprocessors access external memory via an 8-bit Data Bus and 14-bit Address Bus. The TMS 9940 is a one-chip 
microcomputer containing a subset of the TMS 9900 Central Processing Unit, together with on-chip memory and real- 
time clock logic. 

The TMS 9900 product line has for some time been one of the enigmas of the microprocessor industry. Even a 
casual examination of the TMS 9900 instruction set shows that from the programmer's viewpoint, this microprocessor 
was at least two years ahead of its time. While it may have had problems competing in high-volume, simple applica- 
tions, it was certainly the microprocessor of choice for data processing-type, program-intensive applications, yet it was 
not widely used in these markets. 

The reason for this lack of acceptance has been poor support from Texas Instruments. 

Texas Instruments initially offered little support for the TMS 9900 because this microprocessor was designed as a low- 
end product of the TM 990 minicomputer series. That is to say, customers were expected to develop products around 
the TM 990 minicomputers; then, if they chose to, they could build production models around the TMS 9900 
microprocessor. This development path did not call for extensive TMS 9900 support. In all probability, Texas Instru- 
ments was caught by surprise by the buoyancy of the microprocessor market — as a market in its own right. Certainly, 
if Texas Instruments had given the TMS 9900 the same level of support that Intel gave the 8080A, we would see en- 
tirely different microprocessor product distributions today. But the TMS 9900 and its derivative products are powerful 
enough that the belated support they are now receiving from Texas Instruments will give the product line a reasonable 
share of future markets. 

Texas Instruments now provides full support for the TMS 9900 microprocessor line. 

TMS 9900 support devices are designed specifically for the TMS 9900 and can be used with the TMS 9900, 
TMS 9980, or TMS 9940 products. The following devices are described: 

The TIM 9904 Clock Generator 

The TMS 9901 Programmable System Interface 

The TMS 9902 Asynchronous Communications Controller 

The TMS 9903 Synchronous Communications Controller 

Texas Instruments is the primary manufacturer for all of the TMS 9900 series products. TMS 9900 series pro- 
ducts are handled out of the following Texas Instruments office: 

TEXAS INSTRUMENTS. INC. 
P.O. Box 1443 
Houston, Texas 77001 

Second sources for the TMS 9900 family are: 

AMERICAN MICROSYSTEMS, INC. 
3800 Homestead Road 
Santa Clara, California 95051 

SMC MICROSYSTEMS CORP. (TMS 9980 series only) 
35 Marcus Blvd. 
Hauppage, N.Y. 11787 
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THE TMS 9900 MICROPROCESSOR 

The TMS 9900 is manufactured using N-channel silicon gate iVIOS technology. It is packaged as a 64-pin DIP. Three 
power supplies are required: -5V, +5V, and +12V. 

Using a 3 MHz clock, instruction execution times range between 3 and 10 microseconds. 

A TMS 9900 FUNCTIONAL OVERVIEW 

Figure 3-1 illustrates that part of our general microcomputer system logic which is implemented by the TMS 9900 
CPU. 

The most important features of Figure 3-1 are: 

• The absence of programmable registers 

• The presence of significant interrupt handling logic 

• The presence of serial-to-parallel data conversion logic 

• The absence of I/O port interface logic 
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Figure 3-1. Logic of the TMS 9900 CPU 
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Let us first consider the manner in which the TMS 9900 handles programmable registers. 

TMS 9900 PROGRAMMABLE REGISTERS 

Within the logic of the TMS 9900 itself, there are just three 16-bit programmable registers: a Program Counter, a 
Workspace register, and a Status register. 

The Program Counter and Status register are straightforward. The Program Counter contains the address of the 
next instruction to be executed. The Status register maintains various statuses, which we describe later in this chapter. 

The Workspace register is a unique and powerful programming feature of the TIMS 9900. This register identifies 
the first of sixteen 16-bit memory locations which act as 16 General Purpose registers. This may be illustrated 
as follows: 



16-BIT MEMORY 
LOCATION 




xxxx 
xxxx + 2 
xxxx + 4 
xxxx + 6 
xxxx + 8 
xxxx + A 
xxxx + C 
xxxx + E 
xxxx + 10 
XXXX+ 12 
xxxx + 14 
xxxx + 16 
xxxx + 18 
xxxx + 1A 
XXXX+ 1C 
XXXX+ IE 



Special Functions 



RO cannot be an Index register. 
Shift instruction will seek shift 
count in low-order four RO bits if 
instruction object code specifies 
shifts. ^ 



Subroutine return address or XOP effective 
CRU Bit address address 

Save old WP 
Save old PC 
Save old ST 



Some of the 16 registers serve special functions, as defined by the text on the right-hand side of the illustration 
above. For the moment do not attempt to understand these special functions. They are described later in the chapter. 

In TMS 9900 microcomputer systems, external memory consists of 16-bit memory words. 
Each 16-bit memory word has its own memory address. Within the TMS 9900 CPU, 
however, memory is addressed as a sequence of 8-bit locations. For this to occur, the CPU 



TMS 9900 

MEMORY 

ADDRESSES 
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generates an internal 16-bit memory address; the high-order 15 bits of the internal memory ad- 
dress create the external memory addresses. This may be illustrated as follows: 



./^ 



This 16-bit address is created 
by program logic to address 65536 bytes 



^. 



I 

MSB 
15 14 



These 15 address bits are output 
to access 32768 external, 16-bit memory words 



.^^^ 



13 12 11 10 9 8 



1 I 



LSB 



Byte Discrimination Bit 
= Even Byte 
= Odd Byte 
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Bit No. 

Memory Address Inside the CPU 



(LSB)\ 



-AO 

-A1 

-A2 

-A3 

-A4 

-A5 

-A6 

-A7 

-A8 

-A9 

-A10 

-All 

-A12 

-A13 

-A14(MSB)i 



External Address Bus 



When designing hardware around the TMS 9900, you will implement external memory as 1 6-bit words, which are ad- 
dressed by a 15-line Address Bus. That is to say. 32.768 16-bit words may be addressed. 

But when you are programming the TMS 9900 you will visualize memory as 65,536 bytes, addressed by a 16-bit ad- 
dress. An even byte address will access the low-order byte of an external 16-bit memory word, while an odd 
memory address will access the high-order byte of an external 16-bit memory word. 

Any 16 contiguous words of read/write memory may serve as the current 16 general purpose registers for the 
TMS 9900. 

You may have as many sets of 16-bit registers as you wish, limited only by the size of implemented memory. 

If you are using more than one set of 16-bit registers, then at any time just one set of 16-bit registers can be 
selected. The WP register identifies the first of the 1 6 contiguous memory locations serving as the current 1 6 
general purpose registers. 

Each of the 16 general purpose registers may be used to store data or addresses. Thus, each general purpose register 
may serve as an Accumulator or as a Data Counter. 

Registers R11 through R15 are used as special Pointer storage buffers; we will be describing the way in which 
these registers are used as the chapter proceeds. 

Having 16 general purpose registers in read/write memory, rather than in the CPU, is the single most important 
feature of TMS 9900 architecture. The advantage of having 16 general purpose registers located anywhere in 
read/write memory is that you can have many sets of 16 general purpose registers. For example, following an interrupt 
acknowledge, you no longer need to save the contents of general purpose registers — all you need to do is save the 
contents of the Program Counter, the Workspace register and the Status register, and that is done automatically by 
TMS 9900 interrupt handling logic. By loading new values into the Program Counter and the Workspace register, you 



3-4 



TMS 9900 
CONTEXT 
SWITCH 



can begin executing a new program, accessing 16 new memory words — which will be treated as a new set of 16 
general purpose registers. 

The disadvantage of having 16 general purpose registers in read/write memory is that no TMS 9900 microcom- 
puter system can be configured without read/write memory; and if you are going to use many different sets of 1 6- 
bit registers, then you are going to require a significant amount of read/write memory. Furthermore, you lose the speed 
associated with executing register-to-register operations; there are no source and destination locations left in the CPU. 
Every register access becomes a memory access. 

TIVIS 9900 literature refers to the process of switching from one set of general purpose 
registers to another as a context switch. This terminology reflects the complete change of pro- 
gram environment that results from the switch. 

Special instructions allow you to perform a forward context switch or a backward context switch. 

During a forward context switch, you load new values into the Workspace register and Program Counter, while 
simultaneously saving the old Workspace register. Program Counter, and Status register contents in the new General 
Purpose Registers R13, R14, and R15. 

A backward, or reverse context switch loads the current contents of General Purpose Registers R1 3, R14. and R1 5 into 
the Workspace register. Program Counter, and Status register, respectively, thus returning you to your previous set of 
general purpose registers. 

You can perform context switches as often as you like and whenever you like. For example, a very effective way of 
using context switching is to group data into contiguous memory words which you can identify as a register set. Upon 
entering a subroutine, you can perform a context switch which automatically creates all necessary initial data and ad- 
dress values in appropriate general purpose registers. This may be illustrated as follows: 
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As illustrated above, when you perform a forward context switch, the current Program Counter 
contents. Status register contents, and WP register contents are saved in what will become the 
new Registers R13, R14 and R1 5, respectively. Here is the exact sequence in which events oc- 
cur: 



TMS 9900 
FORWARD 
CONTEXT 
SWITCH 



1) The new WP register contents are loaded into the CPU and held in temporary storage. 

2) The current Status register contents are written out to the memory location which will become the new Register 
R15. 

3) The current Program Counter contents are written out to the memory location which will become the new Register 
R14. 

4) The current WP register contents are written out to the memory location which will become the new Register R1 3. 

5) The new WP register contents, which were held in temporary storage, are moved into the WP register 

6) The new value is loaded into the Program Counter 

Thus, when a forward context switch is performed, an audit trail ensures that program logic knows the exact machine 
state at the instant of the forward context switch. 

When a backward context switch occurs, the contents of the current General Purpose 
registers R13, R14, and R15 are loaded into the WP register, the Program Counter, and the 
Status register, respectively. Thus, program logic returns to the location of the forward context 
switch. 



TMS 9900 
BACKWARD 
CONTEXT 
SWITCH 



TMS 9900 MEMORY ADDRESSING MODES 

The TMS 9900 provides these four methods of addressing memory: 

1 ) Direct memory addressing 

2) Direct, indexed memory addressing 

3) Implied memory addressing 

4) Implied memory addressing with auto-increment 

The way in which the TMS 9900 implements these four memory addressing modes is exactly as described in Volume 1 . 
Chapter 6. The important point to note is that the TMS 9900 looks upon its address space as consisting of 32,768 1 6- 
bit memory words which are addressed using 15, rather than 16, Address Bus lines; yet programs compute all ad- 
dresses as 16-bit words. This logic was described earlier. 

Direct memory addressing instructions provide the memory address in the second word 
of an instruction's object code: 
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■Bit No. 
Instruction Object Code 



^l 



Byte identifier recognized by CPU logic 
Direct address output via Address Bus 



Direct, indexed memory addressing instructions provide a base address in the second TMS 9900 
object code word, but they also identify a general purpose register whose contents are INDEXED 
to be added, as a signed binary number, to the base address. Again, the low-order bit of the ADDRESSING 

computed address is not output via the Address Bus, but is interpreted by CPU logic as a byte *-^——^^^^'' 
identifier 

General Purpose Register RO cannot be specified as an index register 

Direct, indexed addressing is very useful in a TMS 9900 microcomputer system. It allows you to address the previous 
set of general purpose registers, following a context switch, without knowing where the previous registers were. Sup- 
pose you want to access the contents of the memory word which was being used as General Purpose Register R5 
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before you switched to your current set of general purpose registers. Recall that the previous Workspace register con- 
tents are stored in your current General Purpose Register R13. You could thus address the previous General Purpose 
Register R5, without knowing where this general purpose register may have been, by using direct, indexed addressing 
as follows: 
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Instruction 
Base Address 

Read/Write 
Memory 



ARBITRARY 

MEMORY 

ADDRESSES 



Previous 
General 
Purpose 
registers 




An implied memory addressing instruction will specify one of the 1 6 current general pur- 
pose registers as providing the effective memory address. 

If you specify implied memory addressing with auto-increment, then the contents of the 

identified general purpose register will be incremented after the memory access has 

been performed. If the instruction specifies a byte operation, the register contents will be incremented by one: the 

register contents will be incremented by two after a full-word operation. 
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Six object code bits identify the data memory addressing option selected by any TMS 9900 instruction that accesses 
data memory. The six object code bits are interpreted as follows: 



0000 through 1111 select the general purpose register to be ac- 
cessed during the memory address computation 



00 - Not a memory reference instruction. The selected register is 
accessed directly. 

01 - Implied memory addressing 

10 - Direct addressing if register RO is selected. 

Direct, indexed addressing otherwise. 

1 1 - Implied memory addressing with auto-increment 



Two-address instructions will include 12 memory addressing option bits: 

MSB LSB 



Two-address instruction object code 



TD 



RD 



TS 



RS 



Destination 
address 



Source 
address 



Some instructions allow a source to be anywhere in memory, but the destination must be a general purpose register. 
These object codes include TS, RS. and RD. but not TD. 

TMS 9900 Jump instructions use program relative, direct addressing. These are one-word 
instructions, where the low-order byte of the instruction object code provides an 8-bit. signed 
binary value, which is added to the incremented contents of the Program Counter. This is 
straightfonward program relative, direct addressing. 



TiVIS 9900 
PROGRAM 
MEMORY 
ADDRESSING 



TMS 9900 I/O ADDRESSING 

As compared to other microcomputers described in this book, the TMS 9900 has unusual I/O logic, in addition toad- 
dressing I/O devices as memory locations, you can address a separate I/O field of up to 4096 bits. Texas Instru- 
ments' literature refers to this field as the "Communications Register Unit" (CRU). If you are programming a TMS 
9900 microcomputer system that has already been configured by Texas Instruments, then it is justifiable to look upon 
the Communications Register Unit as a form of I/O port. If you are building your own interface to a TMS 9900 CPU. then 
instructions that are supposed to access the Communications Register Unit in reality simply make alternative use of 
part of the Address Bus in conjunction with three control signals: CRUCLK, CRUIN. and CRUOUT. 

There are two classes of TMS 9900 CRU instructions. The first class accesses individual bits (or signals), while 
the second class accesses bit fields that may be between 1 and 1 6 bits wide. 

There are three single-bit CRU instructions; they set, reset, or test the identified CRU bit. This is equivalent to set- 
ting, resetting, or testing an external signal or single I/O port bit. When a bit is to be set or reset, the new level is output 
via CRUOUT, and a CRUCLK pulse indicates that valid data is on the CRUOUT line When the condition of a bit is to be 
input or tested, then external logic is required to return the level of the tested bit via CRUIN. 
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A CRU bit instruction outputs a 12-bit address which is connputed as follows: 
Instruction Object Code 



r ^ 

MSB 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 LSB 

I I I I I I I I IxIyIyIyIyFTTFI General Purpose Register R12 




MSB 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 LSB 

I I I |zMz|z|z|z|z|z|z|z|z|z| I 



XXXXXYYYY 
Z Z Z Z Z Z Z Z Z 




C 



Sum becomes effective CRU address 



X, Y and Z represent any binary digits 



The 1 2-bit address is output on the 1 2 tower-order address lines; the three higher-order address lines are all to 
designate a CRU address. 

Now during the execution of a CRU bit instruction, the address which is output is supposed to be a bit address — that 
is. an address identifying one bit in a possible 4096-bit field. So far as external interface logic is concerned, the address 
can be interpreted in any way. However, data output will occur via CRUOUT only: data is input via CRUIN, and 
stored in the Equal bit of the Status register. 

There are two multi-bit CRU instructions: one, LDCR. transfers data fronn an addressed memory location to any ad- 
dressed CRU bit field. The other. STCR. transfers data from an addressed CRU bit field to any addressed memory loca- 
tion. Anywhere from 1 to 16 bits of data may be transferred by the LDCR and STCR instructions. Instruction object 
codes are interpreted as follows: 



MSB 



LSB 



15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 



Bit No. 

Multi-bit CRU Instruction 



Tic 



These four bits identify the general purpose register which is to be 
used in the memory address computation 0000 = RO to 1 1 1 1 = 
Ir15. 

- Register is the memory location 

- Implied memory addressing via address in the register 

- If Register RO is selected, then direct memory addressing is 
specified; the direct address is in the next program memory 
word. If any register other than RO is selected, then direct, in- 
dexed addressing is specified. The contents of the selected 
register are added to the contents of the next program memo- 
ry word. 

.11- Implied memory addressing with auto-increment 

— CRU bit field length (0 is interpreted as 16) 

tool 100 =LDCR 
loOIIOI =STCR 
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The source/destination memory location is identified as it would be for any memory reference instruction. 

The address of the first CRU bit is specified by Register R1 2. For a multi-bit CRU instruction, the CRU bit address is in- 
cremented for each succeeding bit access, but the incremented address is held in a temporary storage location. The 
contents of Register R12 are not incremented 

Thus, multi-bit CRU instructions may transfer anywhere from 1 to 16 bits between any memory location and any CRU 
bit field. Note that memory must be divided into 16-bit words, each of which has identified bit boundaries, but 
there are no equivalent bit boundaries in the CRU bit field. That is to say, any CRU bit may be identified via Register 
R1 2 as the first bit in a multi-bit field, while the length of the multi-bit field is identified by the instruction object code. 
This may be illustrated as follows: 





CRU 






















/ 
















Start of CRU 
Bit Field 



CRU Instruction 
Object Code 



End of CRU 
Bit Field 



If YYYY is 0000, the CRU bit field is assumed to be 16 bits in length. 
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When bits are transferred from a memory location to a CRU bit field, the contents of the memory location are not 
actually modified, but the transfer occurs as though bits had been right shifted out of the memory location. Bits 
arriving within the addressed CRU bit field are stored in sequential CRU bit locations with ascending addresses. This 
may be illustrated as follows: 

CRU 



Data Memory 



XXXXX1 100 1011010 



/ 




Lowest CRU Bit 
Address 



Highest CRU Bit 
Address 



Eleven bits have been transferred in the illustration above. If eight or fewer bits are transferred from a general purpose 
register, only the more significant byte is accessed: 



MSB LSB 

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 



Y I General Purpose Register 



CRU 




Lowest CRU Bit Address 



Highest CRU Bit Address 



Our illustration shows a transfer of five bits. 
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If eight or fewer bits are transferred from a memory location, then the memory address will be considered a byte ad- 
dress rather than a word address; that is, the transfer will be from the low-order bits of the addressed byte, which may 
be either the upper or lower byte of a 16-bit memory word. Thus you can access the lower byte of a general purpose 
register by addressing it as a memory location. 

A data transfer from the CRU to data memory occurs as the exact logical reverse of the illustration above, except 
that high-order bits of the destination data memory word are zeroed if unfilled. This may be illustrated as follows: 



CRU 



Data Memory 



Unused, Therefore Reset 




Lowest CRU Bit Address 



Highest CRU Bit Address 



As with data transfers from memory to the CRU, if eight or fewer bits are transferred, only a byte will be affected. This 
will be either the addressed memory byte: 



CRU 



Data IV^emory 



10 110 



These Bits Reset to 



Lowest CRU Bit Address 



Highest CRU Bit Address 
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or the high-order byte of a general purpose register: 

MSB LSB 

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 



X I General Purpose Register 



This Byte Unaffected 



CRU 



Lowest CRU Bit Address 



Highest CRU Bit Address 



TMS 9900 STATUS FLAGS 

The TMS 9900 CPU has a 16-bit Status register which may be illustrated as follows: 

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 -^-^ — TMS 9900 Bit Number 
15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 < ■ Our Bit Number 



a iui A n A A 



= c 



1 



Status register 

Interrupt mask 

Unused 

XOP instruction executed 

Parity status 
• Overflow status 

Carry status 

Equal condition 
. Arithmetic Greater Than condition 

Logical Greater Than condition 



The low-order four bits of the Status register represent an interrrupt mask which identifies the level of interrupt 
which is currently enabled. As the 4-bit interrupt mask would imply, 1 6 levels of interrupt are allowed. We will describe 
interrupt processing later in this chapter. 

The X status is set to 1 while an XOP instruction is being executed. This instruction allows you to perform a soft- 
ware interrupt — as described later in this chapter. 

The P, O, and C are standard Parity, Overflow and Carry statuses. 

The Equal status (=) identifies a condition that currently exists, as the result of the execution of a previous in- 
struction, that will cause a Branch-if-Equal instruction to branch. A CRU bit to be tested also gets stored in the 
Equal status. 

The Logical Greater Than and Arithmetic Greater Than statuses are set or reset following arithmetic, logical, or data 
move operations. A Logical Greater Than treats the source data as simple, unsigned binary numbers. An 
Arithmetic Greater Than interprets the operand as signed binary numbers. 

TMS 9900 CPU PINS AND SIGNALS 

Figure 3-2 illustrates the pins and signals of the TMS 9900 CPU. 

Being a 64-pin DIP. the TMS 9900 can afford to have separate Address and Data Busses. 
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Pin Name 

AO - AM 

DO - D15 

$1, j)2, <I>3, $4 

MEMEN 

lAQ 

DBIN 

WE 

READY 

WAIT 

CRUCLK 

CRUOUT 

CRUIN 

INTREQ 

ICO - I C3 

HOLD 

HOLDA 

LOAD 



RESET 

VrB' Vco ^dD' Vss 



Description 

Address Bus 

Data Bus 

Clock Signals 

Memory Enable 

Instruction Fetch 

Data Bus In 

Write Enable 

Memory Ready 

Wait State Indicator 

I/O Clock 

Serial I/O Out 

Serial I/O In 

Interrupt Request 

Interrupt Code 

DMA Request 

Hold Acknowledge 

Load Interrupt 

Reset 

Power and Ground reference 



Type 

Tristate, output 

Tristate, bidirectional 

Input 

Tristate, output 

Output 

Tristate, output 

Tristate, output 

Input 

Output 

Output 

Output 

Input 

Input 

Input 

Input 

Output 

Input 

Input 



Figure 3-2. TMS 9900 Signals and Pin Assignnnents 
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Pins AO - A14 provide the 15-bit Address Bus. Note that Texas Instruments' literature nunnbers bits and pins 
from left to right; therefore, address line AO represents the most significant address bit, where as address line 
A14 represents the least significant address bit. 

DO - D15 provide a 16-bit bidirectional Data Bus. Once again, DO represents the most significant data bit in Texas 
Instruments' literature. 

Remaining signals may be divided into bus control, interrupt control, and timing. 

External logic must provide four clock signals, <I>1 , 02, $3, and <I>4. These are provided by the TIM 9904. described 
later in this chapter. 

Any memory access operation begins with an address being output via the Address Bus. The TMS 9900 CPU Iden- 
tifies a stable address on the Address Bus by outputting MEMEN low. 

If the memory access operation is an instruction fetch, the lAQ is output high. 

If the memory access is a read, then the TMS 9900 outputs a high level via DBIN. Memory interface logic must in- 
terpret the high DBIN level as a signal to place data on the Data Bus. 

If the memory access is a memory write, then the TMS 9900 CPU outputs a low pulse via WE. Memory interface 
logic mu st us e the low WE pulse to signal that valid data is on the Data Bus, and to store it in the addressed memory 
location. WE low does not last as long as DBIN high. 

When external logic cannot respond to a memory access in the available time, it requests a Wait state by input- 
ting READY low. The CPU acknowledges by outputting WAIT high. 

CRUCLK, CRUIN, and CRUOUT are three signals used to implement single-bit or serial data transfers via the 
CRU interface. 

CRUOUT is used to output bits of data to the I/O devices, and CRUIN is used to retrieve input data from the I/O devices. 
CRUCLK is active during output operations only, and defines when data bits on CRUOUT are valid. 

Let us now look at interrupt control signals. 



There is a single interrupt request input, INTREQ, which must be held low by any external device requesting an 
interrupt. External devices identify themselves via control signals ICO - IC3. Thus, an interrupt request must be 
accompanied by the appropriate input at ICO - IC3. 

Observe that there is no interrupt acknowledge signal. 



For DMA operations, external logic requests access to the System Bus by inputting HOLD low. The CPU 
acknowledges the Hold request by outputting HOLi)A high. 



LOAD is a nonmaskable interrupt. 



RESET is a typical system Reset signal. However, TMS 9900 Reset logic uses the device's interrupt capabilities; 
therefore, we will describe the Reset operation in detail when discussing TMS 9900 interrupt capabilities in general. 

TMS 9900 TIMING AND INSTRUCTION EXECUTION 

TMS instructions execute as a sequence of machine cycles, each of which contains two clock periods. Clock 
periods are timed by four clock signals, <I>1 , <I>2, <I>3, and 4>4, as illustrated in Figure 3-3. Note that ^2 is the first 
phase of each clock period, and that 4>1 is the last phase. 



The simplest instruction execution machine cycle is an internal operations cycle. No external 
bus signals are active during this machine cycle, and no memory or I/O access occurs. Timing for 
an internal operations machine cycle will consist of two clock periods, as illustrated in 
Figure 3-3. 



TMS 9900 

INTERNAL 

OPERATIONS 

MACHINE 

CYCLE 



MEMORY ACCESS OPERATIONS 

TMS 9900 memory access operations may consist of a memory read or a memory write. An instruction fetch is 
a minor variation of a memory read. 

Figure 3-4 illustrates memory read machine cycle timing. 



MEMEN goes low at the beginning of any memory access machine cycle and stays low for the entire machine cycle. 
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osc 




Figure 3-3. TMS 9900 Clock Periods and Timing Signals as 
Generated by the TIM 9904 



-ONE MACHINE CYCLE 



CLOCK PERIOD 1 



MEMEN 



PBIN 



A0-A14 



D0-D15 



CLOCK PERIOD 2 




INPUT MODE 



XDATA IN I INPUT MODE 



CPU READS DATA 



Figure 3-4. A TMS 9900 Memory Read Machine Cycle 
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DBIN goes high at the begi nning of the memory read machine cycle and stays high for the entire nnachine cycle. Exter- 
nal logic can therefore use MEMEN low as a memory address indicator while DBIN high identifies the read operation. 

A memory address is output stable on the Address Bus for the entire machine cycle. 

The Data Bus operations during a memory read machine cycle represent the only unusual characteristics of the 
machine cycle. Input data needs to be stable during the 4>1 high pulse of the second clock period. However, the Data 
Bus is connected to input logic for the entire memory read machine cycle and for a portion of the next machine cycle. 
Thus, during a memory read machine cycle, external logic cannot access the Data Bus to perform direct memory ac- 
cess, or any other operations, on the assumption that the Data Bus is free until Data In becomes stable. Moreover, since 
the Data Bus is held by data input logic of the GPU during the next machine cycle, a memory read machine cycle can- 
not be followed by a memory write machine cycle. A memory read machine cycle must be followed by an internal 
operations machine cycle, or by another memory read machine cycle. 

The only difference between an instruction fetch machine cycle and a memory read machine cycle is the fact that dur- 
ing an instruction fetch machine cycle, lAQ is output high, along with DBIN, for the duration of the machine cycle. 



-ONE MACHINE CYCLE 



CLOCK PERIOD 1 



CLOCK PERIOD 2 



MEMEN 



WE 



A0-A14 



D0-D15 




ADDRESS OUT 



I 



DATA OUT 



Figure 3-5. A TMS 9900 Memory Write Machine Cycle 



Memory write machine cycle timing is illustrated in Figure 3-5. In this illustration, we see that data is output sta- 
ble on the Data Bus for the entire duration of the memory write machine cycle. The Data Bus is not held by output logic 
beyond this single machine cycle. Thus, no restrictions are placed on the type of machine cycle which can follow a 
memory write machine cycle. Even though data output is stable for the entire memory write machine cycle, the write 
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enable strobe WE does not go low until close to the end of the first clock period. In many cases it is easier to use NOT 
DBIN as a write control signal. Here is the necessary logic: 



MEMEN 



rr^a 



DBIN 



O 



WRITE 



READ 



TMS 9900 instruction execution machine cycle sequences are not always self-evident; therefore, let us look at 
some memory reference examples. 

Mennory address connputations make machine cycle sequences quite complex, particularly for two-operand instruc- 
tions. Fortunately, the exact machine cycle sequences are rarely of any consequence to you as a programmer or logic 
designer. The eventual number of machine cycles required to execute an instruction (and therefore its execution time) 
is important. 

Generally stated, instruction execution proceeds as follows: 

1) The instruction object code is fetched. 
The first operand address is computed. 
The second operand address (if there is one) is computed. 
Any operation that may be required is performed. 
If a result is generated, it is returned to the second operand address. 



TMS 9900 
INSTRUCTION 
EXECUTION 
SEQUENCES 



Let us look at operand address computations using the ADD instruction (A) as a general example. First consider the in- 
struction in its simplest form — where the contents of one register are added to the contents of another register: 







A 


R1,R2 


ycle 


Type 


Figure 


Function 


1 


MEMORY READ 


3-4 


Fetch instruction object code 


2 


ALU 


3-3 


Decode instruction 


3 


MEMORY READ 


3-4 


Fetch R1 contents 


4 


ALU 


3-3 




5 


MEMORY READ 


3-4 


Fetch R2 contents 



ALU 



3-3 Add R1 and R2 contents 



7 MEMORY WRITE 3-5 Store sum in R2 

Now consider the same instruction's execution, but using implied memory addressing for the first operand: 

A *R1,R2 



Cycle Type 



Figure Function 



1 


MEMORY READ 


3-4 


2 


ALU 


3-3 


3 


MEMORY READ 


3-4 


4 


ALU 


3-3 


5 


MEMORY READ 


3-4 


6 


ALU 


3-3 


7 


MEMORY READ 


3-4 


8 


ALU 


3-3 



Fetch instruction object code 

Decode instruction 

Fetch R1 contents 

Use R1 contents as a memory address (implied addressing) 

Fetch contents of implied address location 

Fetch R2 contents 

Add data fetched in cycles 5 and 7 



MEMORY WRITE 3-5 Store sum in R2 



3-18 



If the second (destination) operand uses direct addressing, here is the machine cycle sequence: 

A *R1. ©LABEL 



Cycle Type 



Figure Function 



1 


MEMORY READ 


3-4 


2 


ALU 


3-3 


3 


MEMORY READ 


3-4 


4 


ALU 


3-3 


5 


MEMORY READ 


3-4 


6,7.8 


ALU 


3-3 


9 


MEMORY READ 


3-4 


10 


ALU 


3-3 


11 


MEMORY READ 


3-4 


12 


ALU 


3-3 



Fetch instruction object code 

Decode instruction 

Fetch R1 contents 

Use R1 contents as a memory address 

Fetch contents of implied address location 

Fetch the second instruction object code word; it holds the direct address 

Fetch contents of directly addressed memory word 
Add words fetched in cycles 5 and 1 1 



13 MEMORY WRITE 3-5 Store sum in directly addressed memory word 
Indexed, direct addressing results in the following sequence: 

A *R1,@LABEL(5) 
Function 

Fetch instruction object code 
Decode instruction 
Fetch R1 contents 

Use R1 contents as a memory address 
Fetch contents of implied address location 



Cycle 


Type 


Figure 


1 


MEMORY READ 


3-4 


2 


ALU 


3-3 


3 


MEMORY READ 


3-4 


4 


ALU 


3-3 


5 


MEMORY READ 


3-4 


6 


ALU 


3-3 


7 


MEMORY READ 


3-4 


8 


ALU 


3-3 


9 


MEMORY READ 


3-4 


10 


ALU 


3-3 


11 


MEMORY READ 


3-4 


12 


ALU 


3-3 


13 


MEMORY WRITE 


3-5 



Fetch the second instruction object code word; it holds the direct address 

Fetch R5, the Index register contents 

Add direct address and index 

Fetch contents of memory word addressed by cycle 10 addition 

Add memory words fetched in cycles 5 and 1 1 

Store sum in memory word addressed by cycle 10 addition 

If the first operand-implied address specified an auto-increment, we must add one more machine cycle: 

A *R1-f-,@LABEL(5) 
Function 

Fetch instruction object code 
Decode instruction 
Fetch R1 contents 
increment fetched R1 contents 
Write incremented R1 contents back to R1 
Fetch contents of implied address location 

Fetch the second instruction object code word; it holds the direct address 

Fetch R5, the Index register contents 

Add direct address and index 

Fetch contents of memory word addressed by cycle 1 1 addition 

Add memory words fetched in cycles 5 and 12 

Store sum in memory word addressed by cycle 1 1 addition 



Cycle Type 


Figure 


1 MEMORY READ 


3-4 


2 ALU 


3-3 


3 MEMORY READ 


3-4 


4 ALU 


3-3 


5 MEMORY WRITE 


3-5 


6 MEMORY READ 


3-4 


7 ALU 


3-3 


8 MEMORY READ 


3-4 


9 ALU 


3-3 


10 MEMORY READ 


3-4 


11 ALU 


3-3 


12 MEMORY READ 


3-4 


13 ALU 


3-3 


14 MEMORY WRITE 


3-5 


MEMORY SELECT LOGIC 



MEMEN discriminates between memory and I/O accesses. It is therefore very important that MEMEN low be a 
necessary component for any memory select. 

You can map I/O into the memory space of th e TMS 99 00. This is true of any microprocessor. Memory addresses that 
select I/O devices will, of course, also require MEMEN low as a contributor to I/O device select logic. 
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MEMEN as a contributor to select logic may be illustrated as follows: 



CRU 

SELECT 

LOGIC 



MEMORY 

AND 

MEMORY 

MAPPED 

I/O SELECT 

LOGIC 



SELECT TRUE ONLY IF 
MEMEN IS HIGH AND 
A12-A14 ARE 000 



MEMEN 
AO (LSB) 



All 
A12 
A 14 



(MSB) 




SELECT TRUE 
ONLY IF 



The three high-order address lines, A1 2, A1 3, and A1 4, are not used to address CRU bits. When addressing a CRU bit, 
these lines are all low. They are not low during execution of externally defined I/O instructions; therefore, A12, A13, 
and A14 low must be a prerequisite for any CRU bit select. 

TMS 9900 I/O INSTRUCTION TIMING 

All TMS 9900 I/O instructions transfer serial data via the Communication Register Unit (CRU). (This excludes I/O which 
is addressed as TMS 9900 memory space.) 

There are four types of TMS 9900 I/O instructions. They are: 

1) Data input. Anywhere from 1 to 16 bits of data may be transferred from the CRU bit field to memory. 

2) Data output. This is the simple reverse of data input. Anywhere from 1 to 16 bits of data may be output from 
memory to the CRU bit field. 

3) Bit test. Any bit in the CRU bit field may be tested. The tested bit is input and stored in the Equal bit of the Status 
register. Thence, condition branch instructions can be used to test the bit level. 

4) Externally defined I/O instructions. These instructions generate I/O control signals, but they transfer no data. 

Timing for CRU output and input machine cycles is illustrated in Figures 3-6 and 3-7, respectively. Each of 
these figures shows two bits of data being transferred. (You should not attach any special significance to this fact; de- 
pending on the instruction being executed, anywhere from 1 to 16 bits may be transferred.) CRU machine cycles are 
executed contiguously, one per bit. 
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Every CRU I/O instruction will require a memory reference machine cycle, together with one or more CRU machine cy- 
cles. For example, when an STCR instruction is executed to input data from the CRU to the CPU, the following 
machine cycle sequence will occur: 



Cycle 



Type 



1 MEMORY READ 

2 ALU 
a Cycles, where < a < 4 



3 + a 
4-i-a 
5 + a 

6-i-a 

7 + a 

i Cycles 

8 + a + i 
9-i-a + 1 

r Cycles 

10 + a + i + rto 

12 + a-H + r 

13 + a+ i + r 



MEMORY READ 

ALU 

MEMORY READ 

ALU 
ALU 

CRU IN 

ALU 
ALU 



ALU 

MEMORY WRITE 



Figure 

3-4 

3-3 

1 

3-4 
3-3 
3-4 

3-3 

3-7 

3-3 ' 



3-3 
3-5 



Function 

Fetch Instruction Code 

Decode Instruction 

Obtain Destination Address 

Fetch Destination Memory Word Contents 

Fetch R12 

Compute CRU Starting Address and Prepare 
Control Signals 

Input i CRU Bits 

Load CRU Bits in Temporary Register 

Fill Upper Bits of Byte or Word With Zeroes 
If i>8, r= 15-i; if i< 8, r = 7 - i 

Prepare to Store Memory Word 

Output Assembled Word to Memory Location Whose 
Contents Were Fetched in Machine Cycle 3 + a 



•MACHINE CYCLE 1- 



CLOCK PERIOD 1 



CLOCK PERIOD 2 



•MACHINE CYCLE 1- 



CLOCK PERIOD 1 



CLOCK PERIOD 2 



A0-A14 



CRUOUT 



CRUCLK 




r\_ 



\ 






Figure 3-6. Two TMS 9900 Output-to-CRU Machine Cycles 
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-MACHINE CYCLE 1- 



CLOCK PERIOD 1 



CLOCK PERIOD 2 



-MACHINE CYCLE 2- 



CLOCK PERIOD 1 



CLOCK PERIOD 2 



A0-A14 



CRUIN 




CRU READS BIT 



CRU READS BIT 



Figure 3-7. Two TMS 9900 Input-from-CRU Machine Cycles 

An LDCR instruction outputs a sequence of 1 to 1 6 data bits to a CRU bit field. Here is the LDCR instruction 
machine cycle sequence: 



Cycle Type 

1 MEMORY READ 

2 ALU 

a Cycles where 0<a;^4 

3+a MEMORY READ 
4+a 

to ALU 
7+a 

8+a MEMORY READ 

9+a ALU 

i Cycles CRU OUT 

10-l-a+i ALU 



Figure Function 

3-4 Fetch instruction object code 

3-3 Decode instruction 

J- Obtain source address 

3-4 Fetch source memory word contents 

3-3 Prepare for data transmission 



3-4 Fetch R1 2 

3-3 Compute CRU starting address 

3-6 i Output i bits to CRU 

3-3 Machine cycle to conclude instruction 

The SBO and SBZ instructions set or reset an addressed CRU bit; in essence, these instructions output one data 
bit. Here is the machine cycle sequence via which the bit output occurs: 



Cycle Type Figure Function 

1 MEMORY READ 3-4 Fetch instruction object code 

2 ALU 3-3 Decode instruction 

3 ALU 3-3 Decode instruction 

4 MEMORY READ 3-4 Fetch R1 2 

5 ALU 3-3 Compute CRU address 

6 CRU OUT 3-6 Output to addressed CRU bit 

The TB instruction inputs one CRU bit; its timing is identical to the SBO and SBZ instructions, except that 
machine cycle 6 is a CRU IN machine cycle. 
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The Address Bus is used in an unusual way during a CRU machine cycle. As we have already stated, the CRU bit 

field is 4096 bits wide — addressed by 1 2 of the 1 5 Address Bus lines. The three high-order Address Bus lines are 
used to identify I/O control instructions, as defined in Table 3-1. We can conclude fronn Table 3-1 that when 
MEMEN is high and the three high-order Address Bus lines are all low, an I/O transfer is occurring. Otherwise, one of 
five externally defined I/O control instructions is being executed. There are dedicated functions for these five I/O con- 
trols in TM 990 nninicomputer systems; these are shown in Table 3-1. But to anyone who is simply building a 
microcomputer system around a TMS 9900, these five I/O states are undefined. Thus, Figure 3-8 illustrates TMS 
9900 systems' bus utilization during both CRU operations and externally defined I/O operations. If CRU SEL and 
MEMEN are high, CRU Select logic will be active. 

Externally defined instructions output on the 12 low-order Address Bus lines, AO - A1 1; in addition, CRUCLK 
pulses are output as part of the instruction executions. 

CRUCLK is an active CRU output strobe only. This signal pulses high whenever a valid level is present on the 
CRUO UT signal line. There is no pulse for CRUIN. External logic must generate its own strobe if it is needed, by com- 
bining MEMEN high with a valid bit pattern on the Address Bus. 

CRU instructions that test the level of a bit are, to external logic, no different from CRU input instructions. External logic 
is required to return, via CRUIN the level of the selected bit. The fact that the CPU interprets this input as status, rather 
than data, is immaterial to external logic. 

THE WAIT STATE 

Additional Wait State clock periods may be inserted between clock periods 1 and 2 of any memory access machine cy- 
cle. Timing is illustrated in Figure 3-9. At the rising edge of 4>1 of clock period 1 , the CPU samples the READY input 
signal. If this signal is low, then the next clock period is a Wait clock period. During a Wait cycle, the WAIT output sig- 
nal is high; all other output signals hold the levels they had during clock period 1. 

A Wait State can last for any number of clock periods. During the $1 high pulse of every Wait clock period, the CPU 
samples the level of the READY input. As soon as READY is sampled high, ttie Wait State ends. The next clock period 
becomes clock period 2 of the machine cycle, and the memory operation is completed. 

Table 3-1. High-Order Address Bus Line Used by TMS 9900 I/O Instructions 



Instruction 


Instruction 




(MSB) 




Function 


Mnemonic 


Type 


A14 


A13 


A12 




LDCR 


Output 











Output data to CRU 


SBO 


Output 











Set CRU bit to 1 


SBZ 


Output 











Reset CRU bit to 


STCR 


Input 











Input data from CRU 


TB 


Test (Input) 











Input CRU bit to Equal status bit 


IDLE 


Control 





1 





Enter HALT condition 


RSET 


Control 





1 


1 


Reset the Interrupt mask 


CKOF 


Control 


1 





1 


Real time clock on | jhese are 


CKON 


Control 


1 


1 





Real time clock off jf^ ggo uses. 


LREX 


Control 


1 


1 


1 


Execute bootstrap ) instructions 
are undefined 
in a TMS 9900 
system. 
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-^ A14 
-► A13 
-^- Ai2 

•^ A11 



-»»- AO 
-»► CRUCLK 
■^^ CRUOUT 
CRUIN 



7 
6 
5 
4 
3 
2 
1 







^ 










^ 






CRU SEL 





*■ MEMEN 



LREX 

CKON 

CKGF 

UNUSED 

RSET 

HALT 

UNUSED 



i 



CRU 

SELECT 

LOGIC 



CRU SELECT 
SIGNALS 



If CRU SEL and MEMEN are high, CRU Select logic will be active. 



Figure 3-8. IMS 9900 System Bus Utilization During I/O Operations 
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CLOCK PERIOD 1 



01 
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^ 



CLOCK PERIOD 2 
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03 
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READY 
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Figure 3-9. The IMS 9900 Wait State 
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THE HOLD STATE 

The TMS 9900 has a typical microcomput er Hol d State, used to enable direct memory access operations. Exter- 
nal logic initiates a Hold State by inputting HOLD low. At the beginning o f the nex t no n-m emory reference machine 
cycle, the CPU floats its Address and Data Busses, together with the DBIN, MEMEN and WF control signals. HOLDA is 
output high as a Hold Acknowledge. Timing is illustrated in Figure 3-10. 



(NON-MEMORY 

CYCLE) 

CLOCK PERIOD 1 



HOLD 



HOLD 



CLOCK PERIOD 1 



HOLD 



HOLDA 



D0-D15 



AO-A 



MEM 



14^WE, l~^ 
EN.OBIN (— A 




Figure 3-10. TMS 9900 Hold State Timing 



The Hold State lasts until external logic raises HOLD high again. 

It is up to external logic to perform all operations associated with a DMA transfer. The CPU simply floats the 
System Bus in response to a Hold request 

The only nonobvious aspect of Figure 3-10 is the fact that Data Bus timing, during normal instruction execution, 
differs from other System Bus signal timing. Figure 3-10 highlights this fact by showing the Data Bus floating at 
the beginning of the first HOLD clock period, while other signals float earlier in the preceding clock period. This is not a 
particularly significant event. The entire System Bus is floating once the HOLD clock period has begun. However, the 
actual tristate condition for any signal begins at that point in the preceding clock period when the signal is no longer 
being driven by current operations. 

THE HALT STATE 

The TMS 9900 IDLE I/O instruction generates a Halt State. When this instruction is executed, the CPU suspends all 
progra m execut ion and intern al op eration s. You must terminate the Idle condition with an interrupt request or a low 
LOAD or RESET input. (LOAD and RESET are treated as interrupts as we will describe soon.) 

The TMS 9900 CPU does not relinquish the System Bus while halted. That is to say, after an IDLE instruction has 
been executed, no System Bus lines are floated. 
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The IDLE instruction is usually executed when program logic requires that the CPU wait for an interrupt, or when exter- 
nal logic is connputing a real-tinne interval — which will be ternninated with an interrupt request. 

You can, if you wish, initiate a DiVIA transfer by executing an IDLE instruction. In order to do this, you nnust 
create a HOLD request from the Address Bus output characteristic of the IDLE instruction's execution. This may 
be illustrated as follows: 



A14 (MSB) 
A13 
A12 
CRUCLK 




HOLD 



HOLDA 



END HOLD 



HOLDA 



As illustrated above, the combination of 01 on the three high-order Address Bus lines, along with the CRUCLK pulse, 
identifies the IDLE instruction. Since the process of floating the System Bus will remove the conditions which gener- 
ated a Hold request, these conditions are used to clock a flip-flop. Thus, external logic which receives the Hold 
acknowledge signal and takes control of the System Bus must subsequently reset the Hold request flip-flop in order to 
remove the Hold condition. That is to say, program logic can begin a Hold state within a Halt state, but it cannot 
end this combination. Two steps are needed to terminate a Hold within a Halt. The Hold request must be 
removed, then an interrupt request must follow to terminate the Halt. 

TMS 9900 INTERRUPT PROCESSING LOGIC 

The TMS 9900 has complex and capable interrupt processing logic. Sixteen levels of external interrupt are 
available. Sixteen software interrupts are also available. Fifteen of the sixteen external interrupts are maskable; the 
nonmaskable interrupt has highest priority and is the system Reset interrupt. There is, in addition, a non-maskable Load 
interrupt. External interrupts may be summarized as follows: 



LOAD 






RESET 


Priority 







/ Priority 


1 




Priority 


2 




Priority 


3 




Priority 


4 


Maskable 
Levels of 
External 
Interrupt 


1 Priority 

1 Priority 

J Priority 

Priority 

Priority 


5 
6 

7 
8 
9 




Priority 


10 




Priority 


11 




Priority 


12 




Priority 


13 




Priority 


14 




\ Priority 


15 



Non-maskable, Equal Highest 
Priority Interrupts 



Lowest Priority Interrupt 
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External logic identifies the priority of its interrupt request via the ICO, IC1, IC2, and IC3 inputs, as follows: 



ICO 


IC1 


IC2 


IC3 Priority 











Should not be input by external logic - highest external 











1 1 








1 


2 








1 


1 3 





1 





4 





1 





1 5 





1 


1 


6 





1 


1 


1 7 










8 










1 9 







1 


10 







1 


1 11 




1 





12 




1 
1 
1 




1 
1 


1 13 

14 

1 1 5 lowest external 


Software interrupts 


are executed via the XOP instruction. There are, in addition, in 



RESET and LOAD interrupts. We will describe these instructions in due course. 

Each one of the external interrupts has two dedicated memory words via which vectoring is TMS 9900 
enabled following an interrupt acknowledge. Figure 3-11 illustrates the memory map asso- INTERRUPT 
dated with interrupt vectoring. The nnemory addresses in Figure 3-1 1 are byte addresses as VECTOR MAP 

seen by the programmer. Remember, the low-order bit of the address shown in Figure 3-1 1 is not 

output on the Address Bus; therefore, you must divide the memory addresses shown in Figure 3-11 by 2 in order to 

generate the address which will be seen by external memory. 

The memory words dedicated to interrupt vectoring, as illustrated in Figure 3-11 . can be read-only memory, 
read/write memory, or any combination of the two. Obviously, read-only memory will be used in applications that have 
dedicated interrupt service routines for specific interrupt requests. Read/write memory might be used in minicom- 
puter-type applications where the interrupt response will depend on the application being serviced. 

Interrupt masking and priorities apply only to external interrupt requests. Interrupt masking priorities cannot be 
applied to software interrupts (the XOP instruction). Since program logic must generate the software interrupt, pro- 
gram logic can equally be relied on to know which software interrupt is to be executed, and whether the software inter- 
rupt is allowed by current program logic. That is to say, from the programmer's viewpoint, a software interrupt is simply 
the consequence of an XOP instruction's execution; you, as a programmer, can include an XOP instruction anywhere in 
a program, within or outside an interrupt service routine. XOP instructions might be used in response to error condi- 
tions, or to call any frequently used subroutines. 

Let us begin by looking at the way in which external interrupts are processed. 



Any external device wishing to request an interrupt must pull the INTREQ input low while simultaneously plac- 
ing a 4-bit code at the ICO - IC3 inputs. The CPU will acknowledge the interrupt, provided that Its priority, as 
identified by the ICO - IC3 inputs, is enabled. The interrupt will be acknowledged at the conclusion of the cur- 
rently executing instruction. The BLWP and XOP instructions are exceptions: for the integrity of program logic, 
they demand that the next sequential instruction be executed. Therefore, if an interrupt request occurs while either of 
these two instructions is being executed, the interrupt will not be acknowledged until this instruction and the next in- 
struction have been executed. 
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MEMORY MEMORY WORD CONTENT 
ADDRESS.. 



AREADEFmmON 



INTERRUPT VECTORS 



XOP SOFTWARE TRAP VECTORS 



GBJERAL MEMORY FOR 

PROGRAM, DATA. AND 

WORKSPACE REGISTERS 



0000 
0002 
0004 
0006 



003C 
003E 

0040 
0042 



007C 
007E 
0080 



LOAD SK3NAL VECTOR 



FFFC 
FFFE 



WP LEVEL INTERRUPT 



PC LEVEL INTERRUPT 



WP LEVEL 1 INTERRUPT 



PC LEVEL 1 INTERRUPT 



WP LEVEL 15 INTERRUPT 



PC LEVEL 15 INTERRUPT 



WP XOP 



PC XOPO 



WP XOP 15 



PC XOP 15 



GENERAL MEMORY AREA 
MAY BE ANY 
COMBINATION OF 
PROGRAM SPACE 
OR WORKSPACE 



WP LOAD FUNCTION 



PC LOAD FUNCTION 



Figure 3-11. IMS 9900 Memory Map 
When an interrupt is acknowledged, the following machine cycles are executed: 



Cycle Type 



1 

2 

3 

4 

5 

6 

7 

8 

9 

10 

11 



ALU 

MEMORY READ 

ALU 

MEMORY WRITE 

ALU 

MEMORY WRITE 

ALU 

MEMORY WRITE 

ALU 

MEMORY READ 

ALU 



Figure Function 
3-3 



3-4 
3-3 
3-5 
3-3 
3-5 
3-3 
3-5 
3-3 
3-4 
3-3 



Move new WP register contents from vector word to temporary storage 

Store status in new R15 

Store ICO - IC3 levels in four low-order Status bits 

Store incremented PC in new R14 

Store old WP register contents in new R13 



Fetch new PC contents from vector word 
Fetch new WP contents from temporary storage 

Vector words are illustrated in Figure 3-11. 
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At the conclusion of the interrupt aci<nowledge sequence listed above, the priority of the TMS 9900 
acknowledged interrupt request, less one, is recorded in the four low-order Status register bits. NESTED 
Thus, subsequent interrupt requests will be acknowledged only if their priority is higher than that INTERRUPT 
of the interrupt being serviced. That is to say, whenever an interrupt request occurs, CPU logic PRIORITIES 
compares the levels input at ICO - IC3 with the levels present in the four low-order Status register 
bits. If ICO - IC3 is not greater than the mask, then the interrupt request will be acknowledged. If ICO - IC3 is higher, 
then the interrupt request will not be acknowledged. Thus, in the normal course of events. TMS 9900 interrupt 
priority logic disables all interrupts of equal or lower priority than an acknowledged interrupt, while leaving high- 
er priority interrupts enabled. Priorities are maintained for the duration of the interrupt service routine. This is il- 
lustrated in the following figure, which you should read in the sequence @-(B)-(C)-@-(D-(£)-©: 



© 



Interrupts with 
priorities 5, 8 and 11 
occur simultaneously 



© 



Interrupt with 

priority 5 

acknowledged 



Main Program 



\^ Interrupt with 
priority 7 occurs 
and is deni 



© 



Interrupt with priority 2 

occurs and is 

acknowledged 




Interrupt 7, having highest 
priority of three pending 
interrupts (7, 8 and 1 1 ) will 
immediately be acknowledged 



Interrupt service routine 5 
completes execution 



I nterrupt service 
routine 2 executes 



The interrupt priority arbitration logic of the TMS 9900 is exceptional among microcomputers. Most microcomputers 
arbitrate priorities at the instant interrupts are being acknowledged, and once an interrupt has been acknowledged, all 
interrupts are disabled. That is to say, interrupt priorities apply only during the acknowledge process. In contrast, the 
TMS 9900 maintains interrupt priorities for the duration of the interrupt service routine, as illustrated above. 

The net effect of the interrupt response steps illustrated above is to perform a context switch while disabling all inter- 
rupts that have the same priority as the acknowledged interrupt, or that have a lower priority. 

There are some very important and nonobvious advantages to initiating an interrupt service routine with a con- 
text switch. 

Since the 16 new memory locations that will be used as general purpose registers may lie anywhere in read/write 
memory, you can store parameters that will be used by the interrupt service routine, in advance of the interrupt, in 
those memory locations that are ultimately to serve as general purpose registers for the duration of the interrupt service 
routine. 

You can, if you wish, modify the interrupt priority scheme that will control nested interrupts. As we have already 
stated, if you do nothing about interrupt priorities, then any interrupt service routine may be interrupted by a higher 
priority external interrupt, but not by an external interrupt that has the same priority or a lower priority. 

If you wish to eliminate nested interrupts entirely, then the first instruction executed within an interrupt service routine 
must be an LIMI instruction (Load Int errupt Ma sk Imm ediate), which clears the four low-order Status register bits, 
thus disabling all maskable interrupts. A RESET or LOAD interrupt — or a level external interrupt request — will still 
be acknowledged; these should be alarm conditions and not part of the normal interrupt logic of any microcomputer. 
You can execute variations of the LIMI instruction to increase or decrease the levels of priority that will be masked for 
the duration of any interrupt service routine (or for that matter, any subsequent instruction within the interrupt service 
routine) can load appropriate data into the four low-order bits of the Status register, thus changing the priority level at 
which all subsequent interrupt requests will be disabled. 
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All interrupt service routines should end with an RTWP (Return Workspace Pointer) instruction. The RTWP in- 
struction performs a reverse context switch, which puts the central processing unit back to the logical environnnent 
which was interrupted. Observe that since the Status register is also saved during a forward context switch, the return 
instruction will restore whatever level of interrupt priorities existed at the instant the interrupt was acknowledged. You 
can, of course, modify the contents of General Purpose Registers R13, R14, and R15 in the course of an interrupt ser- 
vice routine's execution. This allows program logic to alter the conditions that will be restored when the return instruc- 
tion executes a reverse context switch. 

The TMS 9901 PSI, which we describe later in this chapter, provides multiple interrupt handling for TMS 9900 
series CPUs. If your system does not include a TMS 9901 , then external hardware required to support multiple 
interrupts in a TMS 9900 microcomputer system will not be as straightforward as the software response. 

First of all, we must cope with the fact that if more than one interrupt request occurs 



simultaneously, then there will be competition on the INTREQ input, but th ere will also be 

competition at the four priority inputs, ICO - IC3. Resolving competition on thelNTREQ input is 

no problem; you can wire-OR interrupt requests from many devices to create the CPU input. 

But your external logic must make sure that only the highest priority combination of ICO - IC3 

appears at the TMS 9900 inputs. One method of doing this is to use latched decoders that 

create a 4-bit output corresponding to the highest level input, provided that the decoder is enabled by a latching sig 

nal. This may be illustrated functionally as follows: 



TMS 9900 

MULTIPLE 

INTERRUPT 

HARDWARE 

CONSIDERATIONS 



I+5V 



TMS 
9900 



INTREQ 



ACQ 



.AC3 



ENABLE 



DECODER 






■A 



^ # 



i i 



(HIGHEST PRIORITY) 
INT 1 



INT 15 
(LOWEST PRIORITY) 



In the illustration above, 15 external interrupt requests are input to a decoder. These interrupt request s are hig h true. 
The 1 5 interrupt requests are buffered, inverted, and wire-ORed to create the master interrupt request INTREQ, which 
is input to the CPU. This master interrupt request also enables the decoder. That is to say, when the enable input to the 
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decoder is high, the four outputs. ICO - IC3 will be low. When the enable input to the decoder is low. ICO - IC3 will out- 
put a 4-bit value as follows: 



'- CM ro 
o O o 



o »- CN CO <* in 

r-CNC3^in«3[^00O)r-»-T-T-r-,- 

h-h-h-J-l-l-l-Hl-l-l-l-l-l-t- 
Z2ZZZZZZZZZZZZ2 



0000000000000 

************* 
1 ************ 
1 *********** 

1 ********* 




r ******** 



****** 
****** 
1 ***** 
1 * * * * 
1 * * * 

1 * * 
1 * 
1 



* REPRESENTS A "DON'T CARE" BIT 
If you do not use the TMS 9901. Texas Instruments suggests the following circuit to acconnplish priority encoding: 




INT 1 (HIGHEST 
• PRIORITY) 



INT 15 (LOWEST 
PRIORITY) 
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External logic must maintain its interrupt request until it receives its own specific interrupt acknowledge. This 
need is obvious, since an interrupt request may be denied for a long time while higher priority interrupts are being ser- 
viced. 

The problem is that the TMS 9900 has no interrupt acknowledge signals. 

Interrupt acknowledge signals can be generated in one of two ways: 

1) By using CRU bit instructions to set and reset external flip-flops that create interrupt acknov\/ledge signals. 

2) By decoding appropriate addresses on the Address Bus. 

Figure 3-12 illustrates two possible configurations that will allow CRU bit set and reset instructions to gener- 
ate interrupt acknowledge signals. The logic in Figure 3-1 2A generates a short interrupt acknowledge pulse. 
CRUOUT becomes the input to a flip-flop which is decoded to generate CRU select si gnals. The CRU bit select and 
MEMEN are gated to the flip-flop's Clear input. Therefore, when CRU bit "n" is selected, CLR is removed and CRUOUT 
can be clocked through. A set bit (SBO) instruction switches the flip-flop on. As soon as the flip-flop address is removed 
at the end of the CRU 1/0 machine cycle, the flip-flop is cleared, thus terminating the interrupt acknowledge pulse. 

The logic illustrated in Figure 3-1 2A requires that you execute an SBO instruction at the beginning of every interrupt 
service routine in order to generate an interrupt acknowledge. You could require every interrupt service routine to con- 
trol the length of the interrupt acknowledge pulse by executing an SBZ instruction to terminate the pulse. Figure 
3-1 28 shows logic to implement this scheme. When the flip-flop is selected by the appropriate CRU address, CRUCLK 
will clock CRUOUT to INT ACK n. At other times. CRUCLK will merely clock the flip-flop's output through, thus making 
no change. In this way, only SBO and SBZ instructions which address INT ACK n can set or reset the flip-flop. 

Figure 3-13 illustrates generation of an interrupt acknowledge signal by identifying specific addresses on the 
Address Bus. Following any interrupt acknowledge, specific memory locations will be accessed, as identified in Figure 
3-1 1 , in order to fetch the new values for the Progra m Counte r and WP register. Figure 3-13 shows a very simple 
scheme whereby Address Bus lines are combined with MEMEN low to generate high pulses for the duration of a valid 
address. That is to say, the interrupt acknowledge signal will last for one machine cycle — the time that the valid ad- 
dress exists on the Address Bus. 

External logic which requested an interrupt removes its interrupt request and priority signals upon receiving an 
interrupt acknowledge. 
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A14 
A13 
A12 
All 

A*0 



MEMEN 



CRUOUT 
CRUCLK 



CRU 
ADDR 



CRU BIT 
ADDRESS 
DECODE 



n SELECT 



A) Logic to create a short INT ACK n pulse 



+ 5V 



PRE 
D Q 



^>CK 



7474 — 
Q 

CLR 




A14 (MSB) 
A13 
A12 
A11 

a6 (LSB) 
MEMEN 



INT ACK n 



n SELECT 



CRUOUT 



CRUCLK 



^D-zzO 





INT ACK n 



B) Logic to have a programmed INT ACK n pulse length 



Figure 3-12. A TMS 9900 Interrupt Acknowledge Pulse Generated Using an SBO Instruction 



A14 



A5 
A4 



A1 



MEMEN 



INTERRUPT n 

SELECT 

LOGIC 



n SELECT 



A14 



A5 
A4 



A1 



MEMEN 



QQQQQ OQQQQQ 



ft OQ QQ QQ 
V-y INTERRU 



PT ADDRESS 



D— 



INT ACK n 



Figure 3-13. TMS 9900 Interrupt Acknowledge Generated by Decoding Valid Addresses 
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THE TMS 9900 RESET 

You reset the 9900 microcomputer s ystem b y inputting a low RESET signal. This signal must remain low for at 
least 3 clock periods. When the low RESET signal is removed, the following machine cycle sequence is ex- 
ecuted : 



Cycle 
1 
2 
3 
4 

5 

6 

7 

8 

9 
10 
11 
12 
13 



Type 
ALU 
ALU 
ALU 
MEMORY READ 

ALU 

MEMORY WRITE 

ALU 

MEMORY WRITE 

ALU 

MEMORY WRITE 

ALU 

MEMORY READ 

ALU 



Figure 
3-3 
3-3 
3-3 
3-4 

3-3 
3-5 
3-3 
3-5 
3-3 
3-5 
3-3 
3-4 
3-3 



Function 

Prepare for Level interrupt 

Fetch new WP register contents from memory word OOOOig to temporary 
storage 

Store Status register contents in new R15 

Store Program Counter contents in new R14 

Store old WP register contents in new R13 

Fetch new Program Counter contents from memory word 0001 15 
Load WP register from temporary storage 

Thus, program execution begins with a program whose starting address is stored in memory word 1. The starting ad- 
dress for the 16 general purpose registers is stored in memory word 0. 

The TMS 9900 has a Reset instruction (RSET). In reality, this instruction resets only the interrupt mask in the Status 
register; it also outputs a code on the Address Bus, as identified in Table 3-1 and illustrated in Figure 3-8. TM 990 
minicomputer systems use this signal to generate a program-initiated Reset. If you are designing your own TMS 9900- 
based microcomputer system, you are free to use the RSET instruction in any way. 

THE TMS 9900 LOAD OPERATION 



The LOAD input to the TMS 9900 is a non-maskable, highest priority interrupt. Load must be input low for at 
least o ne instru ction's duration. Since the length of an instruction can vary, you must use the lAQ signal to con- 
trol the LOAD input pulse width. Texas Instruments' literature recommends the following circuit: 



+5V 




EXTERNAL LOAD 
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The CPU checks LOAD at the end of each instruction's execution. 



After a valid LOAD input has been acknowledged, the following machine cycle sequence is executed: 



Cycle 
1 
2 

3 

4 

5 

6 

7 

8 

9 

10 
11 



Type 
ALU 
MEMORY READ 

ALU 

MEMORY WRITE 

ALU 

MEMORY WRITE 

ALU 

MEMORY WRITE 

ALU 

MEMORY READ 

ALU 



Figure 
3-3 
3-4 

3-3 
3-5 
3-3 
3-5 
3-3 
3-5 
3-3 
3-4 
3-3 



Function 

Input new WP register contents from memory word 7FFEi6 ^o temporary 
storage 

Store in new R15 

Store incremented Program Counter contents in new R14 

Store old WP register contents in new R13 

Input new Program Counter contents from word 7FFF-|5 
Load WP register from temporary storage 



There are two differences between Reset and Load. First, t he RESE T input provides a true hardware reset, syn- 
chronizing internal operations, as well as a level interrupt; LOAD provides only a non-maskable interrupt. Sec- 
ond, the Reset vector in bytes through 3, while the Load vector is in bytes FFFCig through FFFFig. 

In TM 990 minicomputer systems, the LREX instruction is frequently used as a software load. Output due to 
LREX is identified in Table 3-1 and Figure 3-8 . In a TMS 9900 microcomputer system, you can use the LREX 
signal in any way. 

THE TMS 9900 INSTRUCTION SET 

The TMS 9900 instruction set is extremely powerful when compared to any 16-bit microprocessor described in 
this book. When you consider that the TMS 9900 was first manufactured in 1976, the power of this instruction 
set becomes more impressive. 

With regard to instructions described in Table 3-2 , some explanations are required. 

The ABS instruction converts the contents of a memory location to their absolute value. That is to say, this instruction 
assumes that the memory location contains a signed binary number. If the number is positive, nothing happens. If the 
number is negative, the twos complement of the number is taken. 

A number of instructions act on specific bits within source and destination memory words. These include the SOC, 
SOCB, SZC, SZCB. COC, and OZC instructions. In the OPERATION PERFORMED column of Table 3-2, the word 
"corresponding" means that the source word bits are affected only if selected by the destination word bit pattern. For 
example, the SOC instruction will be interpreted as follows: 



Source: 


1 1 


1 1 





1 





1 


1 


1 


1 





1 




Qestination: 


1 1 


1 


■ 


1 


1 





1 








1 







After SOC: 


1 1 


1 1 


■ 


I 


1 


1 


1 


1 


1 


1 


1 


Here are the new destine 
tion contents. 



This is equivalent to an OR operation. 

The SOCB instruction is identical to the SOC instruction, except that only one byte is affected. This may be any memo- 
ry byte or the high-order byte of a general purpose register. 
The SZC instruction may be illustrated as follows: 



Source: 1010011010111001 

Destination: 0^^ 0^ 1 1 1110 10 110 1 

After SZC: 



0101 100100000100 



3-35 



This is equivalent to complementing the source operand and then ANDing the two operands. The SZCB instruction is 
identical to the SZC instruction, except that only one byte is affected. 

The COC instruction compares Source Register 1 bits with general purpose register bits that happen to be in the same 
bit positions. If all corresponding general purpose register bits are also 1 . then the Equal status is set. Matches are not 
significant in bit positions if the source register bit is 0. 

The CZC instruction operates in the same fashion as the COC instruction, except that those source memory word bits 
that are become significant. That is to say, if every source memory word bit has a corresponding Workspace 
register bit, then the Equal status is set. Matches are not significant in bit positions if the source register bit is 1. 

The BLWP instruction is a subroutine call accompanied by a context switch. The operand memory address identifies 
the first of two memory words within which the new WP register and Program Counter contents will be stored. 

The BLWP instruction is remarkably powerful. The subroutine call and passing parameters to the subroutine become a 
single operation. The memory words that are to serve as subroutine general purpose registers can be used as general 
data memory locations prior to the subroutine call. Thus, the subroutine finds its registers pre-loaded with data when it 
starts executing. 

The RTWP instruction should be used to return from a subroutine that is called by the BLWP instruction. 

One-bit position arithmetic shifts may be illustrated as follows: 



Right Shift 



Left Shift 



1011010110100110 
1101101011010011 Lost 



1011010110100110 
Lost 1 1 1 1 1 1 1 1 0, 



A one-bit-position logical right shift may be illustrated as follows: 

101 10101 101001 10 

0101101011010011 Lost 
Inserted 



I nserted 



A one-bit right rotate (Shift Right Circular) may be illustrated as follows: 

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 



IrtHLi-HL-t-HLiM: 



t 



-U-T-hLT, 



You can specify any number of bits, from 1 to 15, as the number of bit positions for any TMS 9900 shift or rotate in- 
struction. If you specify for the bit count, then the actual bit count is taken from the four low-order bits of general pur- 
pose Register RO. If these four low-order bits are 0000, then the bit count is assumed to be 16. 
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The following symbols are used in Table 3-2: 

AG Arithmetic Greater Than status 

C Carry status 

CNT 4-bit count field 

CRUA CRU base address from R1 2 

d Destination memory word. There are five possible options for the destination memory word. They are 

represented by these combinations of addressing modes: 

Workspace Register D 

Implied through Workspace Register D 

Direct address 

Direct, indexed address 

Implied through Workspace Register D, auto-increment Workspace Register D 

DATA4 4-bit data unit 

DATA16 16-bit data unit 

DISP 8-bit signed displacement 

EQ Equal status bit of Status register 

G Both the AG and LG statuses 

LG Logical Greater Than status 

OP Odd Parity status 

OV Overflow status 

PC Program Counter 

R Any of the 1 6 Workspace registers 

Rxx Workspace register. For example. R15 is Workspace Register 15 

S Source memory location. Addressing options identical to destination memory location 

ST Status register 

WP Workspace Pointer register 

x<y.z> Bits y through z of the quantity x. For example, ([S] * [R])<31,16> represents the high-order word of 

the product of the contents of the Source Register S and the Workspace Register R. 
[ ] Contents of location enclosed within brackets. If a register designation is enclosed within the brackets, 

then the designated register's contents are specified. If a memoir address is enclosed within the brackets, 

then the contents of the addressed memory location are specified. 

Multiplication 
/ Division 

A Logical AND 

V Logical OR 

-V- Logical Exclusive-OR 

•^ Data is transferred in the direction of the arrow 

Under the heading of STATUSES in Table 3 -2, an X indicates statuses which are modified in the course of the instruc- 
tion's execution. If there is no X, it means that the status maintains the value it had before the instruction was ex- 
ecuted. 

Byte-operand instructions will affect haK of a 16-bit memory word. If tlie word is accessed as a general purpose 
register, then only the high-order byte will be affected. If the word is accessed as non-register memory, then 
the byte affected is determined by the least significant bit of the 16-bit address: selects the high-order byte; 
1 selects the low-order byte. 
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Table 3-2. 


TMS 9900 Instruction Set Sunnmary 






OPERAND(S) 


BYTES 


STATUSES 


OPERATION PERFORMED 


TYPE 


MNEMONIC 


G 


EQ 


c 


ov 


OP 






LDCR 


S.CNT 


2 


X 


X 






x» 




[CRUA]*-[S<CNT-1,0>] 
Transfer the specified number of bits from source memory word to the CRU. 




STCR 


D.CNT 


2 


X 


X 






X* 




(D<CNT-1,0>]^[CRUA] 


o 




















Transfer the specified number of bits from the CRU to destination memory word. 




SBO 
SBZ 
TB 


DISP 
DISP 
DISP 


2 
2 
2 




X 










[CRUA + DISP]^1 

Set bit in CRU to 1. 
[CRUA + DISP]<-0 

Set bit in CRU to 0. 
If [CRUA + DISP] =0, then [EG] = 1; or else [EQ] =0 

Test bit in CRU. 


>■ S <J 


MOV 


S,D 


2 


X 


X 










[D]-[S] 


K K z 
< O lU 




















16-bit move contents of source memory word to destination memory word. 


i^£ 


MOVB 


S,D 


2 


X 


X 






X 




[D]-[S] 


SsS 




















8-bit move contents of source memory byte to destination memory byte. 




A 


S,D 


2 


X 


X 


X 


X 






[Dl-ESl+CD] 
16-bit add contents of source memory word to contents of destination memory word. 




AB 


S,D 


2 


X 


X 


X 


X 


X 




[D]-[S]+tD] 


Ul 




















8-bit add contents of source memory byte to contents of destination memory byte. 


? 


S 


S,D 


2 


X 


X 


X 


X 






[D]-[D]-[S] 


oe 




















16-bit subtract contents of source memory from contents of destination memory word. 


a. 
o 


SB 


S,D 


2 


X 


X 


X 


X 


X 




[D]-[D]-[S] 


> 




















8-bit subtract contents of source memory byte from contents of destination memory byte. 


K 
O 


C 


S,D 


2 


X 


X 










Set status flags based on 16-bit comparison of source and destination memory word contents. 


s 

Ul 


CB 


S,D 


2 


X 


X 






X 




Set status flags based on 8-bit comparison of source memory byte contents and destination 


1 




















memory byte contents. 


111 

Q 


XOR 


S,R 


2 


X 


X 










[R]-[S]V[R] 


z 




















Exclusive-OR contents of source memory word with Workspace Register R. 


K 


MPY 


S,R 


2 














[R]-[([S]»[R])<31,16>] 


u. 
Ill 




















[R+1]-[([S]«[R])<15,0>] 


oe 
>• 

EC 

o 

S 




















Multiply the contents of source memory word by contents of Workspace Register R. Store most 




















significant word of result in R. Store least significant word of result in Workspace Register R + 1 . 


DIV 


S,R 


2 








X 






[R] — ((R,R+1]/[S]Xquotient) 


Ul 




















[R+ 1]^((R,R+ 1]/[S])(remainder) 


>- 




















Divide the 32-bit quantity represented by R (high-order word) concatenated with R + 1 (low 


cc 
< 




















order) by the contents of the source memory word. Store the quotient in R, the remainder in 


i 




















R + 1 and set overflow if quotient will exceed 16 bits. 


8 


INC 


D 


2 


X 


X 


X 


X 






[D]-[D] + 1 


Ul 
CO 




















Increment contents of memory word by 1. 




INCT 


D 


2 


X 


X 


X 


X 






[D]-(D] + 2 
Increment contents of memory word by 2. 




DEC 


D 


2 


X 


X 


X 


X 






[D]-[D]-1 
Decrement contents of memory word by 1 . 



•OP status is affected only if between 1 and 8 bits are transferred. 











Table 3-2. 


TMS 9900 Instruction Set Summary (Continued) 










STATUSES 






MNEMONIC 


OPERAND(S) 


BYTES 




OPERATION PERFORMED 


TYPE 


G 


EQ 


c 


ov 


OP 






DECT 


D 


2 


X 


X 


X 


X 






[D]-[D]-2 
Decrement contents of memory word by 2. 


O 


CLR 


D 


2 














[D]-O000^g 
Clear the destination memory word. 


UJ 

3 




















z 


SETO 


D 


2 














[Dl^FFF^g 
Set all bits of memory word. 


Z 




















8 


INV 


D 


2 


X 


X 










[d]-["d] 






















Ones complement the destination memory word. 


1 

UJ 


NEG 


D 


2 


X 


X 


X 


X 






.[D]-tDl + 1 




















Twos complement the destination memory word. 


0. 

o 


ABS 


D 


2 


X 


X 


X 


X 






[D]-| [D]| 


^ 




















Take the absolute (unsigned) value of the destination memory word's contents. 


o 


SWPB 


D 


2 














[D<15,8>]< >[D<7,0>] 


111 

S 




















Exchange the high and low bytes of the memory word. 


SOC 


S,D 


2 


X 


X 










If [S<i>]=1,then [D<i>]'-1 


u 

z 

111 
c 
111 
u. 




















Set the bits in the destination memory word that correspond to Is in the source memory word 




















for all 16 bits. 


SOCB 


S,D 


2 


X 


X 






X 




If [S<i>]=1,then [D<i>]-1 


Ill 




















Set the bits in the destination memory word that correspond to Is in the source memory word 


> 




















for 8 bits. 


IE 

o 

lU 


SZC 


S,D 


2 


X 


X 










If [S<i>]=1, then [D<i>]'-p 




















Clear the bits in the destination memory word that correspond to Is in the source memory word 


s 




















for all 16 bits. 


^ 


SZCB 


S,D 


2 


X 


X 






X 




If [S<i>]=1,then [D<i>]— 


< 
o 




















Clear the bits in the destination memory word that con-espond to Is in the source memory word 


z 
o 




















for 8 bits. 


u 
111 


COC 


S,R 






X 










If for all [S<i>]=1, [R<i>]=1,then [EQl—l 


M 


CZC 


S,R 


2 




X 










If the bits in the Workspace Register R that correspond to the set bits In the source memory 
word are all Is, set the EQUAL status. 
If for all [S<i>]=1, [R<i>]=0,then [EQ]=1 
If the bits in the Workspace Register R^at con-espond to set bits in the source memory word 
are all Os, set the EQUAL status. 


III 


LI 


R,DATA16 


4 


X 


X 










[R] — DATA16 


a 




















Load immediate to Workspace Register R. 


S 


LWPI 


DATA 16 


4 














[WR]'-DATA16 


1 




















Load immediate to Workspace Pointer Register, WR. 



Table 3-2. TMS 9900 Instruction Set Summary (Continued) 



TYPE 


MNEMONIC 


OPERAND(S) 


BYTES 


STATUSES 


OPERATION PERFORMED 


G 


EQ 


c 


ov 


OP 




111 

t- 

111 

0. 

O 

o 
111 

S 

S 


CI 

A! 
AND! 
OR! 


R,DATA16 
R,DATA16 
R.DATAie 
R,DATA16 


4 
4 
4 
4 


X 
X 
X 
X 


X 
X 
X 
X 


X 


X 






Set the status flags based on 16-bit comparison between contents of Workspace Register R and 
immediate data. 
[R]— [R1 + DATA16 

Add immediate to Workspace Register R contents. 
[R]— [R] ADATA16 

AND immediate with Workspace Register R contents. 
[R]— [R]VDATA16 

OR immediate with Workspace Register R contents. 


0. 

s 

-J 


B 
JMP 


S 
DISP 


2 
2 














[PC]-[S] 

Branch unconditional to address in Source memory word. 
[PC]-[PC] + DISP 

Branch unconditional. 


z 

E 

< 
u 


BL 
BLWP 

RTWP 


S 

S 


2 
2 

2 


X 


X 


X 


X 


X 




[R11] — [PC] + 1 
[PC]-[S] 

Branch to subroutine at address in source memory word. 
[R13]— [WP] 
[R14]*-[PC] 
[R15]-[ST] 
[WP]-[S] 
[PC]-[S + 2] 

Branch to subroutine whose address is stored in source memory word-t- 1. Perform context 

switch to RO address contained in source memory word. 
[WP]*-[R13] 
[PC1-[R14] 
[ST]— [R15] perform a backward context switch. 


-z 
o 

p 
5 

i 
o 

1 

X 
CO 


JEQ 
JNE 
JGT 
JUT 
JHE 
JH 
JL 
JLE 


DISP 
DISP 
DISP 
DISP 
DISP 
DISP 
DISP 
DISP 


2 
2 
2 
2 
2 
2 
2 
2 














If [EQ]=1;then [PC]<-[PC] + DISP 

Branch if equal. 
If {EQ]=0;then [PC]— [PC] + DISP 

Branch if not equal. 
If [ AG] =1; then [PCl— [PC] + DISP 

Branch on arithmetic greater than. 
If [AG]=Oand [EQ]=0;then [PC]— [PC] + DISP 

Branch on arithmetic less than. 
If [LG]=1 or [EQ]=1;then [PC]— [PC] + DISP 

Branch on logical greater than or equal. 
If [LGl=1 and [EQ]=0; then [PC]— [PC] + DISP 

Branch on logical greater than. 
If [LG]=Oand [EQl=0;then [PC]-[PC] + DISP 

Branch on logical less than. 
If [EQ]=1 or [LG]=0; then [PC]— [PC] + DISP 

Branch on less than or equal. 



Table 3-2. TMS 9900 Instruction Set Sumnnary (Continued) 



TYPE 


MNEMONIC 


OPERAND(S) 


BYTES 


STATUSES 


OPERATION PERFORMED 


G 


EQ 


C 


ov 


OP 




BRANCH ON 
CONDITION 
(CONTINUED) 


JNC 
JNO 
JOC 
JOP 


DISP 
DISP 
DISP 
DISP 


2 
2 
2 
2 














If [C]=0;then [PC]— [PCl + DISP 

Branch on carry reset. 
If [OV]=0;then [PCl—CPC] + DISP 

Branch on overflow reset. 
If [C]=1;then [PC]— [PCl + DISP 

Branch on carry set. 
If [0P]=1;then [PCl-[PC] + DISP 

Branch on odd parity set. 


W E 

S o 


SLA 
SRA 
SRL 
SRC 


R.CNT 
R.CNT 
R.CIMT 
R.CNT 


2 
2 
2 
2 


X 
X 
X 
X 


X 
X 
X 
X 


X 
X 
X 
X 


X 






Arithmetic shift the Workspace Register R left the specified number of bits. 
Arithmetic shift the Workspace Register R right the specified number of bits. 
Logical shift the Workspace Register R right the specified number of bits. 
Rotate the Workspace Register R right the specified number of bits. 


^1 

CO K 

v> 


STST 

STWP 

LIMI 

XOP 


R 

R 

DATA4 

S,R 


2 
2 
4 
2 










X 




[R]-[ST] 

.Store the Status register into Workspace Register R. 
[R]-IWP] 

, Store the Workspace Pointer into Workspace Register R. 
[SR<3,0>] — DATA4 

Load immediate data into the inten-upt mask bits of the Status register. 
[R13]-[WP] 
[R14]-[PC] 
[R15]-[ST] 
[R11]— [S] 

[WP]-[40„ + {4'[R])] 
[PC]-[41„ + (4»[R])] 
Perform a context switch. This is the software interrupt. 


Ili 


X 


S 


2 














Execute the instruction represented by the data in the source location. If that instruction has im- 
mediate operand words, those words must be located directly after the X instruction. The instruc- 
tion [S] will affect the status flags but its fetch will not cause lAQ to go high. 


cc iZ 

Ul III 
Ul 


IDLE 

RSET 
CKOF 
CKON 
LREX 




2 














CPU enters Halt state. 

CPU clears interrupt mask and outputs 001 on three high-order Address Bus lines. 
Oil on three high-order Address Bus lines. 

110 out on three high-order Address Bus lines. 
101 out on three high-order Address Bus lines. 

111 out on three high-order Address Bus lines. 



THE BENCHMARK PROGRAM 

For the TMS 9900, our benchmark program may be illustrated as follows: 

BLWP MOVE CONTEXT SWITCH TO APPROPRIATE REGISTERS 



LOOP MOV @I0BUF(R1).*R2+ LOAD NEXT INPUT WORD IN NEXT TABLE WORD 

DEC R1 DECREMENT COUNT 

JNE LOOP RETURN FOR MORE 

RTWP RETURN FROM SUBROUTINE 

Let us look at how our benchmark program can collapse to just five instructions. 

We assume that there is some set of 1 6 General Purpose registers within which we store the word count and the ad- 
dress of the first free word in TABLE. We illustrated this idea when describing context switching earlier in the chapter. 

Observe that Register R1 contains the word count, and is therefore used as an Index register, while Register R2 ad- 
dresses the first free word in TABLE. Note that the contents of Register R2 are incremented automatically when the 
next byte is loaded into the table. 

The BLWP instruction will branch to the program which performs the required data move, but simultaneously it loads 
the Workspace register with the appropriate initial address. We do not need to load any initial addresses or word 
counts into registers, since we have adopted the memory space where this data is stored to serve as our General Pur- 
pose registers. 

After the nnove has been completed, we do not have to update any counters or pointers, because they were updated 
"in situ". All we have to do upon completing the move is store the contents of the current General Purpose Registers 1 3 
and 14 to the Workspace register and Program Counter. 

The following notation is used in Table 3-3: 

aa Two bits determining the addressing mode for the destination memory word 

bb Two bits determining the addressing mode for the source memory word 

cccccccc 8-bit signed address displacement 

dddd Four bits used with aa to determine the destination memory word 

eeee 4-bit count field 

rrrr Four bits choosing the Workspace register 

ssss Four bits used with bb to determine the source memory word 

XX 16 bits of immediate data 

If either aa or bb is 1 02, and the corresponding register specified is O2. then an additional 1 6-bit direct memory address 
word, used in computing the effective memory address of the operand, will follow the instruction. 

If aa and bb are 1 02. and both corresponding register specifications are 0, then two additional 1 6-bit direct memory ad- 
dressing words will follow the instruction: the first will be used in computing the source address; the second will be 
used in computing the destination address. 
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Table 3-3. TMS 9900 Instruction Set Object Codes 



INSTRUCTION 


OBJECT CODE 


BYTES 


CLOCK 
PERIODS' 


INSTRUCTION 


OBJECT CODE 


BYTES 


CLOCK 
PERIODS* 


A 


S,D 


lOIOaaddddbbssss 


2 


14-30(1) 


JOP 


DISP 


0001 1 lOOcccccccc 


2 


8/10(15) 


AB 


S,D 


1011aaddddbbssss 


2 


14-30(1) 


LDCR 


S.CNT 


OOnOOeeeebbssss 


2 


22-52(11) 


ABS 


D 


000001 noiaadddd 


2 


12-20 (6) 


LI 


R.DATAie 


OOOOOOIOOOOOrrrr 


4 


12(19) 


Al 


R,DATA16 


OOOOOOIOOOIOrrrr 


4 


14(17) 






XX 










XX 






LIMI 


DATA4 


0000001100000000 


4 


16(21) 


ANDI 


R,DATA16 


OOOOOOIOOIOOrrrr 


4 


14(17) 






XX 










XX 






LREX 




0000001111100000 


2 


6(14) 


B 


S 


000001 000 Ibbssss 


2 


8-16 (7) 


LWPI 


DATA 16 


0000001011100000 


4 


10 (20) 


BL 


S 


000001 lOIObbssss 


2 


12-20 (9) 






XX 






BLWP 


S 


OOOOOIOOOObbssss 


2 


26-34 (10) 


MOV 


S.D 


nOOaaddddbbssss 


2 


14-30 (1) 


C 


S.D 


lOOOaaddddbbssss 


2 


14-30(1) 


MOVB 


S.D 


llOlaaddddbbssss 


2 


14-30(1) 


CB 


S,D 


lOOIaaddddbbssss 


2 


14-30 (1) 


MPY 


S.R 


OOmOrrrrbbssss 


2 


52-60 (2) 


CI 


S,D 


OOOOOOIOIOOOmr 


4 


14(18) 


NEG 


D 


OOOOOIOIOOaadddd 


2 


12-20(5) 






XX 






ORI 


R.DATA16 


0000001001 lOrrrr 




14(17) 


CKON 




0000001111000000 


2 


6(14) 






XX 






CKOF 




0000001110100000 


2 


6(14) 


RSET 




0000001101100000 


2 


6(14) 


CLR 


D 


000001001 laadddd 


2 


10-18 (5) 


RTWP 




0000001110000000 


2 


14(8) 


COC 


S.R 


OOlOOOrrrrbbssss 


2 


10-18(1) 


S 


S.D 


OllOaaddddbbssss 


2 


14-30(1) 


CZC 


S,R 


OOlOOIrrrrbbssss 


2 


14-22 (1) 


SB 


S.D 


Omaaddddbbssss 


2 


14-30(1) 


DEC 


D 


000001 lOOOaadddd 


2 


14-22 (5) 


SBO 


DISP 


00011 101 cccccccc 


2 


12(13) 


DECT 


D 


000001 lOOIaadddd 


2 


10-18(5) 


SBZ 


DISP 


0001 11 lOcccccccc 


2 


12(13) 


DIV 


S,R 


OOmirrrrbbssss 


2 


10-18(3) 


SETO 


D 


000001 llOOaadddd 


2 


10-18 (5) 


IDLE 




0000001101000000 


2 


6(14) 


SLA 


R.CNT 


OOOOIOIOeeeerrrr 


2 


14-52(16) 


INC 


D 


00000101 lOaadddd 




16-124 (5) 


SOC 


S.D 


mOaaddddbbssss 


2 


14-30(1) 


INCT 


D 


000001011 laadddd 


2 


10-18 (5) 


SOCB 


S.D 


nilanddddbbssss 


2 


14-30(1) 


INV 


D 


OOOOOIOIOIaadddd 


2 


10-18 (5) 


SRA 


R.CNT 


OOOOIOOOeeeerrrr 


2 


14-52 (16) 


JEQ 


DISP 


0001001 Icccccccc 


2 


10-18(15) 


SRC 


R.CNT 


0000101 leeeemr 


2 


14-52 (16) 


JGT 


DISP 


OOOIOIOIcccccccc 


2 


8/10(15) 


SRL 


R.CNT 


OOOOIOOIeeeemr 


2 


14-52 (16) 


JH 


DISP 


0001 101 Icccccccc 


2 


8/10(15) 


STCR 


D.CNT 


OOllOleeeeaadddd 


2 


42-60 (12) 


JHE 


DISP 


OOOIOIOOcccccccc 


2 


8/10(15) 


SISI 


R 


000000101 100mT 


2 


8 (23) 


JL 


DISP 


OOOIIOIOcccccccc 


2 


8/10(15) 


STWP 


R 


000000101010rrrr 


2 


8(22) 


JLE 


DISP 


OOOIOOIOcccccccc 


2 


8/10(15) 


SWPB 


D 


000001 101 laadddd 


2 


10-18 (23) 


JLT 


DISP 


OOOIOOOIcccccccc 


2 


8/10(15) 


SZC 


S.D 


OlOOaaddddbbssss 


2 


14-30(1) 


JMP 


DISP 


OOOIOOOOcccccccc 


2 


10(15) 


SZCB 


S.D 


OlOlaaddddbbssss 


2 


14-30(1) 


JNC 


DISP 


0001011 Icccccccc 


2 


8/10(15) 


TB 


DISP 


0001 111 Icccccccc 


2 


12(8) 


JNE 


DISP 


000101 lOcccccccc 


2 


8/10(15) 


X 


S 


OOOOOIOOIObbssss 


2 


8-16(7) 


JNO 


DISP 


OOOIIOOIcccccccc 


2 


8/10(15) 


XOP 


S.R 


00101 Irrrrbbssss 


2 


44-52(4) 


JOC 


DISP 


0001 lOOOcccccccc 


2 


8/10(15) 


XOR 


S.R 


OOlOIOrrrrbbssss 


2 


14-22(1) 



' The number in brackets identifies the instruction's machine cycle sequence, as defined in the preceding text. 
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The minimum and maximum number of clocic periods for the execution of each instruction are shown in the 
CLOCK PERIODS column of Table 3-3. Remember that a machine cycle consists of two clock periods. The 
bracketed number after the numbisr of clock periods identifies the machine cycle sequence. Machine cycle se- 
quences associated with each bracketed number are listed below. In the machine cycle list below, the follow- 
ing abbreviations are used: 

R represents a memory read machine cycle as identified in Figure 3-4. 

A represents an ALU machine cycle as illustrated in Figure 3-3. 

W represents a memory write machine cycle as illustrated in Figure 3-5. 

C represents a CRU machine cycle as illustrated in Figures 3-6 and 3-7. 

A subscript associated with any machine cycle notation identifies that machine cycle repeated a number of times. Thus 
A3 is equivalent to -A-A-A-. 

M represents memory address computation machine cycles. Memory address computations were described earlier in 
this chapter In summary, here are the various possibilities for M: 
Register addressing: R 

Implied memory addressing: R-A-R 

implied memory addressing with auto-increment (for byte operand): R-A-W-R 
Implied memory addressing with auto-increment (for word operand): R-A-A-W-R 



Direct addressing: 


A-A-R-A-R 


Direct, 


indexed addressing: 


R-A-R-A-R 


(1) 


R-A-M-A-M-A-W 




(2) 


R-A-M-A-R-A18-W-A-W 




(3) 


R-A-M-A-R-A-A-R-Ax-W-A-W (51 < x 4: 35) 




(4) 


R-A-M-A3-R-A-W-A-W-A-W-A-W-A-R-A 




(5) 


R-A-M-A-W 




(6) 


R-A-M-A3-W-A 




(7) 


R-A-M-A 




(8) 


R-A-A-R-R-R-A 




(9) 


R-A-M-A-A-W 




(10) 


R-A-M-A-A-W-A-W-A-W-A-R-A 




(11) 


R-A-M-A4-R-A-CX-A (16 < X < 1) 




(12) 


R-A-M-A-R-A-A-Cx-Aw-W (16<x<1,11<y<5) 




(13) 


R-A-A-R-A-C 




(14) 


R-A-A-C-A-A 




(15) 


R-Ax (x=3 or 4) 




(16) 


R-A-R-A-A-R-Ax-W-A (1 8 <: x < 3) 




(17) 


R-A-A-R-R-A-W 




(18) 


R-A-R-A-R-A-A 




(19) 


R-A-A-R-A-W 




(20) 


R-A-A-R-A 




(21) 


R.A-A-R-A3 




(22) 


R-A-A-W 




(23) 


R-A-M-A-R-A4-W 





THE TMS 9980A AND THE TMS 9981 MICROPROCESSORS 

The TMS 9980A and the TMS 9981 are low-cost variations of the TMS 9900. The principal differences be- 
tween the TMS 9900 series and TMS 9980 series microprocessors are summarized in Table 3-4. Differences 
between the TMS 9980A and the TMS 9981 are summarized in Table 3-5. 

This discussion of the TMS 9980 series microprocessors covers only differences as compared to the TMS 9900. 

The TMS 9980 series microprocessors are manufactured using N-channel silicon gate MOS technology. They are 
packaged as 40-pin DIPs. The TMS 9980A uses three power supplies: -5V. -I-5V, and -1-1 2V. The TMS 9981 uses two 
power supplies: -I-5V and -1-1 2V. 

Typically, a clock cycle time of 400 nanoseconds will be used with TMS 9980 series microprocessors. This generates 
instruction execution times ranging between 4 and 14 microseconds. 
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Figure 3-14 illustrates that part of general microcomputer system logic which is implemented by the TMS 
9980 series microprocessors. This figure is identical to Figure 3-1, with the exception of clocl< logic, which is now 
shown present. 

Programmable registers are implemented and used in exactly the same way the TMS 9900 and TMS 9980 
series microprocessors. Note, however, that the TMS 9980 series microprocessors address a 2048-bit CRU; 

therefore, bits 1 through 1 1 of Register R1 2 identify the origin of any CRU bit field. The TMS 9900 uses bits 1 through 
12 of Register R12 to identify the CRU origin within a 4096-bit CRU. 

Table 3-4. A Summary of Differences Between the TMS 9900 and TMS 9980 Series Microprocessors 



FUNCTION 


TMS 9900 


TMS 9980A/TMS 9981 


Addressable external memory 


32,768 X 16-bit words 


16,384 X 8-bit words 


DIP pins 


64 


40 


Data Bus 


16 bits 


8 bits 


Address Bus 


15 bits 


13 bits 


External interrupt priorities 
CRU field width 


15 
4096 bits 


4 
2048 bits 


Clock logic 


Four external inputs 


One external input 

or internal (TMS 9981 

only) 



Table 3-5. A Summary of Differences Between the TMS 9980A and TMS 9981 Microprocessors 



FUNCTION 


TMS 9980A 


TMS 9981 


Power supplies 


-5V, -1-5 V, +12V 


-I-5V, -f-12V 


Clock logic 


One external input 


One external input 
or crystal only 


Pin incompatibility ties 


DO - D7, INTO - INT2. <P3 | 



The TMS 9980 series microprocessors have a 14-line Address Bus, used to address up to 16,384 bytes of 
memory. In contrast, the TMS 9900 addresses up to 32,768 16-bit words of external memory. Thus. TMS 9980 pro- 
grams address memory as bytes, while externally generated addresses also select bytes. The TMS 9900, by way of con- 
trast, addresses memory as bytes within the CPU, but as 16-bit words externally. 

The TMS 9980 series microprocessors use exactly the same memory and CRU addressing techniques as the 
TMS 9900. General-purpose registers are used in the same way, and instruction object codes are identical. 

The Status register and Status flags used by the TMS 9980 series microprocessors are identical to those which 
we have already described for the TMS 9900. 

TMS 9980 SERIES MICROPROCESSOR PINS AND SIGNALS 

Figure 3-15 illustrates pins and signals for the TMS 9980A. Figure 3-16 provides the same information for the 
TMS 9981. In both of these illustrations, signal names conform to Texas Instruments nomenclature. For the Data and 
Address Busses, our notation is given in brackets. Differences result from the fact that we number bits from right to left 
(0 being the low-order bit), while Texas Instruments numbers bits from left to right (0 becomes the high-order bit). TMS 
9980A/TMS 9981 pin-out differences are shaded in Figures 3-15 and 3-16 so that you can identify them 
quickly. 

For descriptions of the individual signals, refer to the earlier TMS 9900 discussion. 
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Clock Logic 



Logic to Handle 
Interrupt Requests 

from 
External Devices 



Interrupt Priority 
Arbitration 



Arithmetic and 
Logic Unit 



Instruction Register 



Control Unit 



Bus Interface 
Logic 



I 



Accumulator 
Register<s) 



Data Counter<s) 



Stack Pointer 



Program Counter 



Direct Memory 

Access Control 

Logic 



I 



System Bus 



I 



I/O Communication 
Serial to Parallel 
Interface Logic 



Programmable 
Timers 



ROM Addressing 

and 
Interface Logic 



I 



I '0 Ports 
Interface Logic 



Read-Only 
Memory 



I/O Ports 



RAM Addressing 

and 
Interface Logic 



Read/Write 
Memory 



Figure 3-14. Logic of the TMS 9980A and TMS 9981 Microprocessors 
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HOLD 

HLDA 

lAQ 

(LSB) (AO) CRUOUT/A13 

(A1) A12 

(A2) All 

(A3) A10 

(A4) A9 

(A5) A8 

(A6) A7 

(A7) A6 

(A8) A5 

(A9) A4 

(A10) A3 

(A11)A2 

(A12) A1 

(MSB) (A13) AO 

DBIN 

CRUIN 

(+5V) Vcc 




1 

2 

3 

4 

5 

6 

7 

8 

9 

10 

11 

12 

13 

14 

15 

16 

17 

18 

19 

20 



TMS 
9980A 



40 
39 
38 
37 
36 
35 
34 
33 
32 
31 
30 
29 
28 
27 
26 
25 
24 
23 
22 
21 




MEMEN 
READY 
WE 

CRUCLK 
Vdd ( + 12V) 

Vgg (GND) 

CKIN 



D7 (DO) 
D6 (D1) 
D5 (D2) 
D4 (D3) 
D3 (D4) 
D2 (D5) 
D1 (D6) 
DO (D7) 
INTO 
INT1 
JM^T2 
<p3 
Vbb(5V) 



(LSB) 



(MSB) 



Pin Name 
A0-A13 
D0-D7 
CKIN 
03" 

MEMEN 
lAQ 
DBIN 
WE 

READY 
WAIT 
CRUCLK 
CRUOUT 
CRUIN 
INTO, INT1, INT2 



HOLD 
HOLDA 



V V V V 

BB' CC DD' SS 



Description 
Address Bus 
Data Bus 
Clock signal in 
Synchronizing clock 
Memory Enable 
Instruction Fetch 
Data Bus in 
Write Enable 
Memory Ready 
Wait State indicator 
I/O clock 
Serial I/O out 
Serial I/O in 

Interrupt request and priority 
DMA request 
Hold acknowledge 
Power and Ground reference 



Type 
Tristate, output 
Tristate, bidirectional 
Input 
Output 

Tristate, output 
Output 

Tristate, output 
Tristate, output 
Input 
Output 
Output 
Output 
Input 
Input 
Input 
Output 



Figure 3-15. TMS 9980A Signals and Pin Assignments 
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HOLD 

HLDA 

lAQ 

(LSB) (AO) CRUOUT/A13 

(A1) A12 

(A2) All 

(A3) A10 

(A4) A9 

(A5) AS 

(A6) A7 

(A7) A6 

(AS) A5 

(A9) A4 

(A10) A3 

(All) A2 

(A12) A1 

(MSB) (A13) AO 

DBIN 

CRUIN 

(+5V) Vcc 

Pin Name 
A0-A13 
D0-D7 
CKIN 
OSCOUT 
03" 

MEMEN 
lAQ 
DBIN 

wi 

READY 

WAIT 

CRUCLK 

CRUOUT 

CRUIN 

INTO, INT1, INT2 




MEMEN 

READY 

WE 

CRUCLK 

Vdd(+12V) 

Vgg (GND) 



HOLD 
HOLDA 



V , V , V 
CC DD' SB 



Description 
Address Bus 
Data Bus 

Clock or crystal connection 
Crystal connection 
Synchronizing clock 
Memory Enable 
Instruction Fetch 
Data Bus in 
Write Enable 
Memory Ready 
Wait State indicator 
I/O clock 
Serial I/O out 
Serial I/O in 

Interrupt request and priority 
DMA request 
Hold acknowledge 
Power and Ground reference 



CKIN 
OSCOUT 
D7 (DO) 
D6 (DD 
D5 (D2) 
D4 (D3) 
03 (D4) 
D2 (D5) 
D1 (D6) 
DO (D7) 
INTO 
INT1 
INT2 
03 



(LSB) 



(MSB) 



Type 
Tristate, output 
Tristate, bidirectional 
Input 
Output 
Output 

Tristate, output 
Output 

Tristate, output 
Tristate, output 
Input 
Output 
Output 
Output 
Input 
Input 
Input 
Output 



Figure 3-16. TMS 9981 Signals and Pin Assignments 
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TMS 9980 SERIES MICROPROCESSOR TIMING AND INSTRUCTION EXECUTION 

The TMS 9980A and TMS 9981 microprocessors have the same signal relationships and instruction execution 
sequences as the TMS 9900. The few minor waveform differences are identified in the data sheets at the end of 
this chapter. 

The only significant difference between the TMS 9900 and TMS 9980 series is in clock logic. The TMS 9900 re- 
quires four clock inputs, as identified in Figure 3-3. 

Tlie TMS 9980A requires a single clock signal, input via CKIN. The frequency of this clock input 
must be four times the desired clock frequency. That is to say. CKIN will be divided by four in 
order to create one clock period. The TMS 998 1 can operate with the same CKIN input as the TMS 
9980A; however, you can also connect a crystal across CKIN and OSCOUT. This may be illustrated 
as follows: 



TMS 9980 
SERIES 
CLOCK 
LOGIC 



CKIN 



OSCOUT 



X 

n 

X 



C2: 



CI 



CI and C2 must have values between lOpf and 25pf, typically 15pf. 

The crystal must be of the fundamental frequency type. The frequency will be divided by four in order to create the in- 
ternal clock frequency. 

Both the TMS 9980A and the TMS 9981 output 4)3, a synchronizing clock signal. $3 is the inverse of the 03 clock sig- 
nal shown in Figure 3-3 and in subsequent timing diagrams for the TMS 9900. 

Thus you can create the timing diagram for any TMS 9980 operation by looking at the equivalent timing diagram for 
the TMS 9900 and replacing the four TMS 9900 clock signals by a single timing pulse which will be the complement of 
4)3 

The following operations are identical within TMS 9900 and TMS 9980 systems: 

• Memory references. However, note that memory reference will consist of two memory access cycles, as a 1 6-bit word 
is handled as two bytes. 

• CRU I/O operations (remember that the TMS 9980 series CRU is only 2048 bits wide). 

• CRU control operations 
•The Wait state 

•The Hold state and direct memory access operations 

•The Halt state 

•The interaction of Hold and Halt states 

Refer to the TMS 9900 discussion for any of the above topics. 

TMS 9980 SERIES INTERRUPT LOGIC 

The TMS 9980A and TMS 9981 microprocessors support four levels of external interrupt, together with a Reset and a 
Load. Reset and Load are non-maskable interrupts. In contrast, the TMS 9900 supports 15 levels of external interrupt, 
along with Reset. 

The TMS 9980 series microprocessors identify external interrupts via the INTO, INT1, and INT2 inputs as 
shown in Table 3-6. Figure 3-17 shows the interrupt vector map. 
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Table 3-6. TMS 9980 Interrupts 



INTO 


INTl 


INT2 


Interrupt Decoded 











Reset 








1 


Reset 





1 





Load 





1 


1 


Level 1 (Highest Priority) 


1 








Level 2 


1 





1 


Level 3 


1 


1 





Level 4 (Lowest Priority) 


1 


1 


1 


No Interrupts 



Observe that the TMS 9980A and the TMS 9981 have no INTREQ input. Also, the Reset and Load non-maskable inter- 
rupts are decoded from the INTO - INT2 inputs. 

Figure 3-18 shows some pin connections for various levels of interrupt complexity in a TMS 9980 series microcom- 
puter system. The three illustrations shown are self-evident; they simply implement the INTO - INT2 codes defined 
above. 

The TMS 9980 series microprocessors provide all 16 XOP software interrupts available with a TMS 9900. 

Observe that Figure 3-17 shows memory as 8-bit units in contrast to Figure 3-11, which shows memory as 16-bit 
units. This reflects the fact that external memory is addressed as bytes by the TMS 9980A and the TMS 9981. 
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Memory 
Address 



Memory Byte 
Content 



Reset 



/ 



External Interrupt / 



Unassigned Memory 
for Programs or Data 



XOP Vectors, Use 

Same Memory Space / 

as the TMS 9900 



Unassigned Memory 



Load 



0000 
0001 
0002 
0003 

0004 
0005 
0006 
0007 
0008 
0009 
OOOA 
OOOB 
OOOC 
OOOD 
OOOE 
000 F 
0010 
0011 
0012 
0013 



0040 
0041 
0042 
0043 



007 C 
007 D 
007 E 
007 F 



3FFC 
3FFD 
3FFE 
3FFF 



WP 


HI 


WP 


LO 


PC 


HI 


PC 


LO 


WP 


HI 


WP 


LO 


PC 


HI 


PC 


LO 


WP 


HI 


WP 


LO 


PC 


HI 


PC 


LO 


WP 


HI 


WP 


LO 


PC 


HI 


PC 


LO 


WP 


HI 


WP 


LO 


PC 


HI 


PC 


LO 


1 


1 


WP 


HI 


WP 


LO 


PC 


HI 


PC 


LO 


1 


1 


WP 


HI 


WP 


LO 


PC 


HI 


PC 


LO 


1 


1 


WP 


HI 


WP 


LO 


PC 


HI 


PC 


LO 



WP 
PC 
WP 
PC 
WP 
PC 
WP 
PC 
WP 

PC 



PC 



WP 



PC 



WP 



PC 



Reset Vector 



Level 1 Vector 



Level 2 Vector 



Level 3 Vector 



Level 4 Vector 



XOP Vector 



XOP 15 Vector 



Load Vector 



Figure 3-17. TMS 9980 Memory Map 
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RESET 



LEVEL 4 



INTO 
INT1 
INT2 

TMS 9980A/ 
TMS 9981 



LEVEL 1 



RESET 



LOAD 







1 


INTO 

TMS 9980A/ 
TMS 9981 

INT1 

INT2 




r- y- 











A) Using Reset and One 
External Interrupt 



B) Using Reset, Load and 
One External Interrupt 





vcc 
o 










i 




A 


"1 






1— a 


7 El 

6 

5 A2 

4 A1 

3 AO 

2 

1 
SN74148 
(TIM 9907) 




INTO 
INT1 
INT2 

TMS 9980A/ 
TMS 9981 














LEVEL 1 — 




r 












LEVEL 3 — 








LEVEL. 4 







C) Using Reset, Load and Four External Interrupts 



Figure 3-18. Some TMS 9980A/TMS 9981 Interrupt Interfaces 

The interrupt acknowledge process and interrupt priority arbitration logic are identical in TMS 9900 and TMS 
9980 series microprocessors. For a discussion of these subjects, refer to the earlier TMS 9900 description. 

THE TMS 9980 SERIES INSTRUCTION SET 

The TMS 9900 and TMS 9980 series microprocessors have identical instruction sets. Instructions execute in almost the 
same sequences of machine cycles — the only difference is that each memory reference will have twice as many 
memory access cycles. Refer to Tables 3-2 and 3-3, together with their accompanying text, for details. Remember to 
substitute two memory cycles for each TMS 9900 memory cycle. 

THE TMS 9940 SINGLE-CHIP MICROCOMPUTERS 

The TMS 9940 is a single-chip microcomputer based on the TMS 9900 microprocessor. Figure 3-19 illustrates 
that part of our general microcomputer system logic provided by the TMS 9940 series microcomputer. 

Specifically, this is the logic provided by the TMS 9940 series microcomputers: 

•A Central Processing Unit, essentially equivalent to the TMS 9900 Central Processing Unit 

• 2048 bytes of read-only memory. Erasable Programmable Read-Only Memory (EPROM) is provided by the TMS 
99400E. Normal mask programmable Read-Only Memory (ROM) is available with the TMS 9940M. 

• 128 bytes of read/w/rite memory. This read-write memory is frequently organized as four sets of sixteen 16-bit 
registers. 
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•Two levels of externa! interrupt 

•An on-chip timer/event counter with its own interrupt logic 

• 32 I/O pins accessed as 32 CRU bits 

•A single +5V power supply 

•On-chip clock logic 



Clock Logic 



Logic to Handle 
Interrupt Requests 

from 
External Devices 



Arithmetic and 
Logic Unit 



Instruction Register 



Control Unit 



Interrupt Priority 
Arbitration 



Bus Interface 
Logic 



Accumulator 
Register(sl 



Data Counterls) 



Stack Pointer 



Program Counter 



System Bus 



.'0 Communication 
Serial to Parallel 
Interface Logic 



Programmable 
Timers 



ROM Addressing 

and 
Interface Logic 



I/O Ports 
Interface Logic 



Read-Only 
Memory 



I/O Ports 



Direct Memory 

Access Control 

Logic 



I 



I 



RAM Addressing 

and 

Interface Logic 



Read/Wnte 
Memory 



Figure 3-19. Logic of the TMS 9940 Single-Chip Microcomputers 

The TMS 9940 microcomputer has very little expansion logic; 256 external CRU bits can be addressed, but 
there is no provision for executing programs directly from external memory. 

But the TMS 9940 is easily included in multiprocessor configurations. For multiprocessor configurations, the TMS 
9940 has internal Hold request/acknowledge logic, together with a serial I/O path via which data can be transferred 
between processors. 
The TMS 9940 has two +5V power supplies: a standard operating power supply and a standby power supply. 

Under program control, it is possible to shut down the TMS 9940, in which case only the standby power supply is ac- 
tive. An external interrupt can subsequently restart the TMS 9940. 

The TMS 9940 is manufactured using N-channel silicon gate MOS technology. It is packaged as a 40-pin DIP. 
Using a 3 MHz clock, instruction execution times range between 3 and 10 microseconds. 
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This description of the TIVIS 9940 microcomputer relies on the preceding detailed description of the TMS 9900. 
This description of the TMS 9940 does not stand alone, and you should not read it until you understand the TMS 
9900 in detail. 

TMS 9940 REGISTERS AND READ/WRITE MEMORY 

There are some important conceptual differences between the read/write memory/registers of the TMS 9940 
and those of the TMS 9900. 

The TMS 9940 has only 128 bytes of read/write memory, with all the read/write on the chip itself, and you cannot 
create an external Data/Address Bus. Therefore, it makes no difference whether memory is addressed as bytes or 
words. The only remaining restriction is that 16-bit words must be origined on even byte address boundaries. 



/ 



ROM 



< 



0000 


WP HI 
WP LO 


0002 


PC HI 
PC LO 


0004 


WP HI 
WP LO- 


0006 


PC HI 
PC LO 


0008 


WP HI 
WP LO 


OOOA 


PC HI 
PC LO 


OOOC 


WP HI 
WP LO 


OOOE 


PC HI 
PC LO 


0010 




0012 





WP 
PC 
WP 
PC 
WP 
PC 



Reset Vector 



Level 1 Interrupt Vector 



Decrementer Vector 



Level 2 Interrupt Vector 



/ 



004E 
0050 

0052 
0054 
0056 

007C 

007 E 
0080 

07FF 



WP HI 
WP LO 



PC HI 
PC LO 



WP HI 
WP LO 



PC HI 
PC LO 



Unused and Available for Programs 
RAM 





WP HI 
WP LO 


PC HI 
PC LO 





WP 
PC 
WP 
PC 

WP 
PC 



XOP 4 Vector 



XOP 5 Vector 



XOP 6 - XOP 14 Vectors 



XOP 15 Vector 



Unused and Available for Programs 



8300 




RO 


8302 




R1 








831C 




R14 


831 E 




R15 


8320 




R1 


8322 




R2 








833C 




R14 


833 E 




R15 


8340 




R1 


8342 




R2 








835C 




R14 


835E 




R15 


8360 




R1 


.8362 




R2 




I 




837C 




R14 


837E 




R15 



Register Set 1 



Register Set 2 



Register Set 3 



Register Set 4 



Figure 3-20. TMS 9940 Memory Map 
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The TMS 9940 does introduce one additional read/write nnennorY restriction: the 128 bytes of read/write memory 
are divided into four non-overlapping sets of sixteen 16-bit registers, as illustrated in Figure 3-20. Note that the 
1 28 bytes of read/write nnemory have specifically defined addresses. Both the TMS 9900 and the TMS 9980 series 
microprocessors allow any sixteen 16-bit words of memory to serve as a set of general purpose registers, whether or 
not they overlap with another set. 

The TMS 9940 has the same three CPU registers as the TMS 9900: the Program Counter, the Workspace register, 
and the Status register. The TMS 9940 sets aside general-purpose registers to serve specific functions, as does the 
TMS 9900. 

Given the configuration of the TMS 9940, many register designations can be justified only as a means of preserving 
TMS 9900 series compatibility. For example, a 16-bit TMS 9940 Workspace register makes no sense when there are 
only 64 locations that the Workspace register can possibly address. Moreover, the whole idea of context switching — 
and tying up three 1 6-bit registers in order to execute a context switch — is ridiculous, given the few places to which 
you can context switch. 

But there is long-range sense in the TMS 9940 design. Over the next few years, enhancements of the TMS 9940 will 
appear with substantially more memory — both read-only memory and read/write memory. Since it is absolutely im- 
perative that TMS 9940 programs be compatible with new, enhanced one-chip microcomputers that are likely to ap- 
pear, it is necessary that addressing modes and architectural features that influence the instruction set be included in 
the TMS 9940 if they will be useful in later enhancements. 

Despite the fact that the TMS 9940 has only 1 28 bytes of read/write memory and 2048 bytes of read-only memory, the 
TMS 9940 has all of the TMS 9900 memory addressing modes. Note carefully that so far as memory addressing is con- 
cerned, there is no difference between read-only memory and read/write memory. Many one-chip microcomputers 
have a scratchpad read/write memory which can only be accessed as data memory, while a separate program memory 
can only store instruction sequences, the TMS 9940 makes no such distinction between its read-only memory and 
read/write memory. Data and instructions can be stored in read-only memory or in read/write memory. 

The TMS 9940 and TMS 9900 CRU addressing techniques are identical; however, the TMS 9940 has just 32 exter- 
nal CRU bits, each with its own dedicated pin. By configuring 1 1 of these pins as address lines and CRU controls, you 
can expand external CRU to 256 bits. 

There are some small differences between the TMS 9930 Status register as compared to the TMS 9900 Status register 
The TMS 9940 Status register may be illustrated as follows: 



1 2 3 4 5 6 7 8 9 10 11 12 13 14 15-^TMS 9900 Bit Number 
15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 ■«- Our Bit Number 



AC 




I I Status Register 



Interrupt Mask 

Unused 

Half Carry Status 

Parity Status 

Overflow Status 

Carry Status 

Equal Condition 

Arithmetic Greater Than Condition 

Logical Greater Than Condition 



TMS 9940 L, N, =. C. 0, and P statuses are the same as those of the TMS 9900. 

The TMS 9940 has no XOP instruction executed status, which the TMS 9900 holds in Status register bit 9. 
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The TMS 9940 has an AC status in bit 8. This is a half-carry status. For byte-oriented instructions, AC represents the 
carry from the low four bits to the higher four: 



7 6 5 4 3 2 1 0^ Bit No. 

Q I Memory Byte 



P Q Q 



u 



AC = 1 for Carry 
AC = for No Carry 



15 14 13 12 11 10 9 8 7 6 5 4 



0-«- Bit No. 



F 



u 



N I General-Purpose Register 



Byte instructions operate on the 
high-order byte of a register. 

For 16-bit instructions, the AC status represents a carry from bit 1 1 to bit 12: 



15 


14 


13 


12 


11 


10 


9 


8 


7 


6 


5 


4 


3 


2 


1 


- 


tl 


P 


P 


P 


Q 


Q 


± 


Q 


R 


R 


R 


R 


S 


S 


S 


iJ 



u 



^K Bit No. 

Memory Word or 
General-Purpose Register 



AC = 1 for Carry 
AC = for No Carry 



Since there are just four levels of external interrupt, the TMS 9940 uses Status register bits and 1 for its interrupt 
mask. In contrast, the TMS 9900 uses Status register bits 0, 1,2, and 3 for its interrupt mask. 

TMS 9940 CPU PINS AND SIGNAL ASSIGNMENTS 

Figure 3-21 illustrates the pins and signals of the TMS 9940 microcomputer. 

PO - P31 and 32 I/O pins addressed as 32 CRU bits. Some of these pins serve additional functions which can be 
selected under program control. 



3-56 



The TMS 9940'can, in fact, use standard IMS 9900 CRU instructions tb address up to 512 CRU bits. But 51 2 is the 

maximum nunnber of CRU bits that the TMS 9940 can address. Therefore, the TMS 9940 uses just 9 bits of General Pur- 
pose Register R12 to create CRU bit addresses. For a single-bit CRU instruction, this may be illustrated as follows; 



Instruction Object Code 

MSB LSB 

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 




Sum Becomes Effective 
CRU Address 
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1 40 

2 39 

3 38 

4 37 

5 36 

6 35 

7 34 

8 33 

9 32 

10 TMS 31 

11 9940 30 

12 29 

13 28 

14 27 

15 26 

16 25 

17 24 

18 23 

19 22 

20 21 




■■"" ''SS l^'^'-'' 


IDLE/P16 -^ — ► 

TD/P12 -^ ^- 


■^ ^- P7/A8 (LSB) 

■^ ^ P5/A6 
^ — ^. P4/A5 
1^ » P3/A4 


(IDV) VjjQi 


CRUCLK/P10 -^ — ^ 

CRUOUT/P9 -^ — ^ 

CRUIN/P8 ^ ^ 


RST/PE ^ 







Pin Name Description Type 

PO - P31 CRU I/O pins Bidirectional 

INT1/TST External interrupt and Test select Input 

INT2/PR0G External interrupt and EPROM programmer Input 

RST/PE System reset and EPROM programmer enable Input 

AO - A7 External CRU bit address Output 

CRUCLK External CRU clock Output 

CRUOUT External serial I/O output Output 

CRUIN Extemal serial I/O input Input 

TC Multiprocessor data I/O clock Bidirectional 

TO Multiprocessor data I/O Bidirectional 

EC Event counter input Input 

IDLE Idle state indicator Output 

HLD Hold request Input 

HLDA Hold acknowledge Output 

4> Synchronizing cicjck Output 
XTAL2, XTAL1 Extemal crystal connections 

Vqc^ Standby + 5V power 

Vc(;2 Normal + 5V power 

Vgs Ground reference 

(In this figure, Pn and An numbering conforms to Texas Instruments' policy of beginning with N=0 for the high-order bit. We use N=0 
for the low-order bit.) 



Figure 3-21. TMS 9940 Microcomputer Signals and Pin Assignnnents 
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Table 3-7 shows how the TMS 9940 interprets its 512 available bit addresses. 

Table 3-7. TMS 9940 CRU Bit Address Assignments 



CRU 
Address 



Read Function 



Write Function 



000 to 
OFF 

100 to 
17F 

180 

181 

182 

183 

184 

185 

186 

190 to 
19D 

19E 

19F 

lAOto 
1AF 

IBOto 
1BF 

ICO to 
IDF 

lEOto 
IFF 



) External CRU bits; the address is output via A1-A8. Data is transferred via CRUIN, CRUOUT 
) andCRUCLK 



I Unused 

INT1 state 

Decrementer interrupt level 

INT2 state 

Unused 

Unused 

Unused 

Unused 



Unused 

Unused 

Clear decrennenter interrupt 

Unused 

Configuration bit (CBO) 

Configuration bit 1 (CB1) 

Configuration bit 2 (CB2) 

Configuration bit 3 (CBS) 



Decrementer register. 190 is the least significant bit and 19D is tiie most significant bit 



Unused 
Unused 



Timer (high) or Counter (low) select 
Unused 



) Multiprocessor System Interface buffer register 

' 1 AO is the least significant bit and 1 AF is the most significant bit 

1^ General purpose flag bits 



t Unused 

I Local CRU pins (TO = 1E0, P31 = IFF 



Identify direction for PO (via ICO) through P31 (via IDF). 
1 specifies output. specifies input 



The place to begin looking at Table 3-7 is at CRU bits 183, 184, 185, and 186. These four 
CRU bits represent write-only locations which determine how the 32 CRU pins illustrated in Figure 
3-21 will be used. 



TMS 9940 
CRU BIT 
UTILIZATION 



if you look again at Figure 3-21, you will see that PO through PI 7 have shared functions. PI 8 
through P31 are simple I/O pins without other programmable options. 

CRU addresses 183, 184. 185 and 186 control the functions of PO through PI 6, as illustrated in Table 3-8 . P1 7 

options depend on real-time clock logic, which we will describe later. 

Let us look at the programmable options available with CRU pins PO through P31. 

It does not matter what options you have selected; you will actually access the 32 CRU pins PO - P31 via CRU ad- 
dresses IEO16 through IFFig. 

In the simplest case, all 32 pins, PO - P31, will be used for input or output. We call this Sim- 
ple I/O mode. In order to use all 32 pins for data input or output, (that is, in Simple I/O mode), all 
four of the configuration bits, CBO, CB1, CB2, and CB3, must be 0. At any time, a CRU bit can 
either input data or output data, but it cannot be used for bidirectional data transfer. You must 
identify the direction for each pin by outputting appropriate data to CRU addresses ICOig 
through IDFig. As shown in Table 3-7 , each pin has a dedicated CRU address, beginning with pin PO controlled by 



TMS 9940 
SIMPLE 
CRU I/O 
MODE 
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1C0i6 and ending with pinP31 controlled by CRU address IDFis A 1 written to any Direction CRU bit causes the as- 
sociated pin to output data only. A written to any CRU Direction bit causes the associated pin to input data only. Of 
course, you can at any time change a pin from input to output or from output to input, under program control, by 
rewriting control information to Direction CRU bits ICOig through IDFis- 



Table 3-8. TMS 9940 CRU Bits Whose Functions 


are Determined Under Program Control 


CRU 


Function as Configured 1 


Bit 


Address 


Pin 


CB0 = 


CB0 = 1 


CB1,CB2,CB3 


0-7 


1 EO-1 E7 


23-30 


P0-P7 


A1-A8 


No Effect 


8 


1E8 


18 


P8 


CRUIN 


No Effect 


9 


1E9 


17 


P9 


CRUOUT 


No Effect 


10 


1EA 


16 


P10 


CRUCLK 


No Effect 




CB1 =0 


CB1 =1 


CB0,CB2,CB3 


11 


1EB 


14 


P11 


TO 


No Effect 


12 


1EC 


11 


P12 


TD 


No Effect 




CB2 = 


CB2 = 1 


CB0,CB1,CB3 


13 


1ED 


15 


P13 


(> 


No Effect 




CB3 = 


CB3 = 1 


CB0.CB1,CB2 


14 


1EE 


10 


P14 


HLD 


No Effect 


15 


1EF 


9 


P15 


HLDA 


No Effect 


16 


1F0 


8 


P16 




No Effect 


IDLE 



You will always have to define the direction of data transfer for pins PI 8 through P31 — assuming that you are using 
these pins. When pins PC through PI 7 are being used in any of the special ways which we are about to describe, then 
the data direction associated with the special operation will apply, and it makes no difference what you output to the 
associated Direction CRU bit. 



If you wish to use 266 external CRU bits, then you must set CRU bit 1 83 (CBO) to 1 . This is TMS 9940 
called I/O expansion mode. I/O expansion mode modifies the functions of pins PC through PIG. CRU I/O 
When you use CRU addresses 00 through FFis in I/O expansion mode, the address is output via EXPANSION 
pinsP0-P7, which now function as CRU address lines A1 - A8. P8, P9, and PlOsen/eas thestan- MODE 

dard CRU data transfer lines: CRUIN, CRUOUT, and CRUCLK. Timing for data input and output via ^~~~~'"''""~ 
these three lines has been described for the TMS 9900. Refer to the TMS 9900 description for details. In order to il- 
lustrate the use of external CRU, consider execution of the instructions: 

LOAD 1010 BINARY INTO UPPER BYTE OF R3 
LOAD A BASE ADDRESS OF 82 HEX INTO R1 2 
OUTPUT FOUR LOW-ORDER BITS OF R3 TO CRU 

Note that R12 contains 0140-|6 to represent the address 082-16- since R12 bit is unused; therefore the internal ad- 
dress is, in effect, doubled. 

This instruction outputs 1010 toCRU bit082i6 (0). 083i6 (D, 084i6 (0), and OSBied)- Sincefewer than eight bits will 
be transferred, they will come from the upper byte of the general purpose register. This is the event sequence which 
occurs: 

1) The address 82-|6 is output via A1 - A8. Remember, Texas Instruments' literature uses to represent the high- 
order bit; therefore A1 represents the high-order address bit, and A8 represents the low-order address bit. CRUIN is 
inactive, but CRUOUT is low to represent while CRUCLK is pulsed high to time the bit on CRUOUT. 



LI 


R3,>00 


LI 


R12,>140 


LDCR 


R3,4 
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2) The address output on A1 - A8 increments to 83-|6. and CRUOUT goes high, then CRUCLK pulses high. 

3) The address on A1 - A8 increments to 84i6. CRUOUT goes low again, and CRUCLK pulses high. 

4) The address on A1 - A8 increments to 85-|6. and CRUOUT goes high, and CRUCLK pulses high. 

1010 has now been transmitted to four external CRU bits. 

Note that it is up to external logic to decode the CRU address output; however, the Parallel System interface (which we 
will describe in later editions) will connect directly to the TMS 9940 Address and CRU outputs that we have just de- 
scribed. 

When you write 1 to CRU bit 184ie (CB1), pins P11 and PI 2 function as serial data 
transfer pins. The purpose of this logic is to allow the TMS 9940 to operate in multi-CPU 
configurations. This logic is very simple. You output data by writing the data to CRU bits 
IAO16 through IAF-15. This data is immediately transmitted via TO (P12) as a serial data 
stream which is clocked by TC (P11). in keeping with normal bit sequence protocol, data is 
transmitted low-order bit first. Thus, 16 bits of data being output may be illustrated as follows: 
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When a TMS 9940 has a 1 written toCBI, it can also receive data via TD. Data input is again clocked byTC. Input logic 
is the reverse of the output logic illustrated above; that is say, as a data stream is input, the first input bit is loaded into 
CRU bit IAF-16' and the sixteenth input bit is loaded into CRU bit lAOig. 

TMS 9940 multiprocessor system interface logic is used to transfer data from a memory location in one TMS 
9940 to a memory location in another TMS 9940. You will not normally use this logic to transfer data between a 
TMS 9940 and external logic; the CRU serves that purpose better. There are three reasons why you may want 
to use the TMS 9940 multiprocessor system interface; they are: 

1) To transmit status information. For example, one TMS 9940 could tell another how far it has progressed through 
various phases of a task by transmitting a status word whose bits have some predefined interpretation. 

2) To transmit data. One TMS 9940 may generate data which another TMS 9940 needs in order to execute its pro- 
grams. 

3) To transmit instruction sequences. Instructions could be transmitted from the read-only memory (or the 
read/write memory) of one TMS 9940 to the read/write memory of another TMS 9940. The receiving TMS 9940 
could then execute the instruction sequence out of its read/write memory. 
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Figure 3-22. Handshaking Logic in a TIVIS 9940 Multi-Microcomputer Network Connnnunicating via the TD Data Line 
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You could use the CRU to perform any of the three data transfers described above, but the multiprocessor system inter- 
face is somewhat easier to use. We say that data transfer via the multiprocessor system interface is "somewhat" easier 
to use because many problems still remain when you use the multiprocessor system interface. These problems arise 
from the fact that there is absolutely no handshaking protocol associated with the multiprocessor system inter- 
face. For example, there is absolutely no protection against twoTMS 9940s simultaneously trying to output data via 
TD and TC. There is no predefined protocol whereby a transmitting TMS 9940 identifies the receiving TMS 9940 or the 
instant data has been transmitted and should be read. Any protocol is your responsibility — to be provided by logic ex- 
ternal to the TMS 9940s. Fortunately, this protocol is easy to implement. Figure 3-22' shows how eight TMS 
9940s can communicate with each other, such that each TMS 9940 may transmit data to, or receive data from, 
any other TMS 9940. The logic illustrated in Figure 3-22 is more complex than the logic you would need for a small 
system — for example, a two-microcomputer system, or a system where there are dedicated transmitters and receivers. 

While Figure 3-22 shows TMS 9940s communicating with each other, you will in fact use TMS 9940s just as fre- 
quently with other microprocessors — such as a TMS 9900. Nevertheless, the concepts embodied in Figure 3-22 
would apply, from the viewpoint of the TMS 9940. in any other configuration. 

Let us look at how the logic in Figure 3-22 works. 

The first problem we must resolve is the problem of transmission contentions. How will we make sure that one TMS 
9940 does not try to transmit data while another TMS 9940 is already transmitting data? A simple scheme would be to 
set aside a particular CRU pin to serve' as a "Busy" line. For example, every TMS 9940 could useP31 as a "Busy" output 
pin and P30 as a "Sense" input pin. We could wire-OR together all P31 Busy outputs and input this wire-OR to ail P30 
Sense inputs. Now any TMS 9940 that wishes to transmit data will read its P30 CRU bit. If this bit is 0. then it will out- 
put 1 toP31. Outputting 1 toP31 causes all other TMS 9940s to receive 1 at their P30 inputs. Thus, no other TMS 9940 
will begin transmitting data if another TMS 9940 was in the process of transmitting data. This logic may be illustrated 
as follows: 



P31 



P30 




All TMS 9940s 
now receive 
a high P30 



Another 
TMS 9940 
senses P30 
high — so 
does not 
try to 
output 



The problem with the logic illustrated above is that two TMS 9940s could simultaneously read P30, find it was 0, out- 
put 1 to P31, then output competing data on TD. While the chances of two microcomputers executing identical in- 
structions at exactly the same time are very small, a well-designed microcomputer system must account for every po- 
tential error. In Figure 3-22 we resolve our problem by using a 74148 8-to-3 decoder. The P31 output from every TMS 
9940 is connected to a different 74148 input. The 74148 outputs, via OO. 01, and 02, the line number for the highest 
priority active input. This three-line output is connected to the P28, P29, and P30 pins of every TMS 9940; we assume 
that these three pins are inputs at every TMS 9940. Now every TMS 9940 that wishes to transmit data via TD must out- 
put a 1 to P31 . It must then input the contents of P30, P29. and P28. Upon detecting its own ID on these three inputs, it 
begins data transmission. If a TMS 9940 outputs 1 via P31 and then reads in some other ID via P30. P29, and P28. then 
it must wait. Here is an appropriate instruction sequence: 

LOAD P28 ADDRESS, X2. INTO R12 
SET P31 ON 
LOOP STCR R2.3 INPUT P28. P29. AND P30 

COMPARE INPUT WITH DEVICE ID 
RETURN AND RE-ENTER CODE IF NOT CORRECT ID 
LOAD MPSI OUTPUT DATA BASE ADDRESS X2 
OUTPUT CONTENTS OF R3 VIA TD 



LI 


R12.>3F8 


SBO 


3 


STCR 


R2.3 


CI 


R2.ID 


JNE 


LOOP 


LI 


R12,>340 


LDCR 


R3.16 
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Assuming that a TMS 9940 has output 1 to P31 and has received back its own ID via P28, P29, and P30. the TMS 9940 
is ready to transmit data. However, in addition to simply transmitting the data, the TMS 9940 must tell the intended 
recipient that the data has been transmitted. In Figure 3-22 we use a 74138 3-to-8 demultiplexer for this purpose. 
Pins P25, P26, and P27 of every TMS 9940 are outputs that connect to the 10, II. and 12 inputs of the 74138. The 
transmitting TMS 9940 outputs data which will be received by every other TMS 9940; however, the transmitting TMS 
9940 follows up by outputting a 3-bit code via P25. P26, and P27; this 3-bit code identifies the intended recipient. The 
3-bit code is input to the 74138. which generates one of eight possible outputs. These eight outputs become external 
interrupt request inputs to the eight TMS 9940s. Only the single TMS 9940 will receive the data which was transmitted 
by the eighth TMS 9940. only one TMS 9940 will receive an interrupt request signal; this is the TMS 9940 for which 
the transmitted data was intended. The TMS 9940 which receives data simply executes an STRCR instruction to move 
the data from CRU bits lAO-jg through lAFig to the appropriate general purpose register. 

CRU bit 185-16, ^^^ ^^2 bit, serves the very limited purpose of outputting a synchronizing 
signal. When you output 1 to CB2, PI 3 ceases to be an I/O pin and instead outputs the inter- 
nal TMS 9940 clock signal. 

CRU bit 18616 (CB3) controls idle and hold logic for the TMS 9940. When you write a 1 to CRU bit 186 ig. pinsP14 
and P I 5 act as hold request input (HLD) and hold acknowledge output (HLDA) signals, respectively. PI 6 generates an 
IDLE output. 

The Hold request/acknowledge logic of the TMS 9940 is quite standard. The purpose of this 
logic is to remove the TMS 9940 from any shared busses when some other microp roces sor or 
microcomputer is bus master. If CB3 is 1. then a low signal arriving at the TMS 9940 HLD input 
will cause the TMS 9940 to enter a Hold state at the conclusion of the current instruction's execution. A low HLDA out- 
put marks the beginning of the Hold state. 



TMS 9940 
SYNC MODE 



TMS 9940 
HOLD LOGIC 



The IDLE signal is output low when an IDLE instruction is executed and CBS i s 1 . The only TMS 9940 
way in which you can terminate an Idle state is by requesting an interrupt via INT1 or INT2. The IDLE LOGIC 

TMS 9940 three-state signals are not floated in the Idle state. You must additionally enter the Hold ^^^— — ^^ 
state for this. 

The purpose of the IDLE instruction and signal is to enable standby power logic. This may be illustrated as follows: 



+5V Q 



-^cc-" 



IDLE LOW OPENS SWITCH 



IDLE 



HLD 



-^cc2 



Under normal circumstances, the power supply will input power to Vccl and Vcc2. When IDLE goes low. the power 
input to Vcc2 is switched off. While V^c^ only is receiving power, the TMS 9940 read/write memory and interrupt 
logic is active, but all other logic is inactive, since the interrupt logic is activ e, any arriving interrupt request will be 
acknowledged. The process of acknowledging an interrupt request sets IDLE high again. This closes the switch and 
restores power to Vcc2. which allows the TMS 9940 to resume normal execution. 

In the illustration above, note that IDLE is connected to HLD. 
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TMS 9940 GENERAL PURPOSE FLAGS 

If you look again at Table 3-7 , you will see that CRU addresses IBOfg through IBFig address 16 general pur- 
pose flags. These general purpose flags have no special hardware functions. They are programming aids and thai 
is ail. You can write data out to these flags, and you can read back the data. How you use this data is entirely up to pro- 
gram logic. 

TMS 9940 TIMER/EVENT COUNTER LOGIC 

The TMS 9940 has a timer which can also be used as an event counter. CRU bit 1 9Ei g determines whether this 
logic will function as a timer or as an event counter. If CRU bit 1 9Ei g is high, then this logic serves as a Timer. If 
CRU bit 19Eie is 1°^' ^'i*" ^^^'^ 'ofl'^ serves as an event counter. 

Timer and Event Counter logic both use CRU bits 190i6 through 19D-16 ssa 14-bit register whose contents are decre- 
mented by Timer or Event Counter logic. This 14-bit register is buffered. That is to say. the initial value which you out- 
put to CRU bits 190i6 through 19Di6 is stored in a buffer, in addition to being loaded into CRU bits 190i6 through 
19Di6- Subsequently. CRU bits 190i6 through 19Di6 are decremented, but the buffer contents remain unaltered. 
When CRU bits 190i6 through 19Di6 decrement to 0, they are reloaded from the buffer. Thus Timer/Event Counter 
logic runs continuously. An interrupt request is generated internally when CRU bits 190-16 through 19Di5 decrement 
toO. 

Remember, CRU bit 1 90i q is the low-order bit, and CRU 1 9Di 6 is the high-order bit. This is the reverse of normal Texas 
Instruments bit numbering, where the high-order bit has the lowest bit number. However, this is consistent with the 
fact that Texas Instruments outputs data to the CRU low-order bit first, and addresses CRU bits in numerically ascend- 
ing address sequence. 

When you write to CRU bits 190i6 through ISD-ig. you disable Timer/Event Counter logic. 

When the Timer/Event Counter is operating as a timer, the 14-bit register represented by CRU bits 190ic 
through 19Di6 are decremented once every 30 internal clock oscillations. The crystal connected across XTAL1 
andXTAL2 determines clock oscillation frequency. When CRU bits 190i6 through 19D|6 time out to zero, an interrupt 
request is generated. 

When Timer/Event Counter logic is operating as an event counter, pin PI 7 serves as an input, receiving the 
event sequence to be counted. Every low-to-high transition of the signal input at PI 7 decrements the counter. Once 
again, when the counter counts out to 0. an interrupt request occurs and the counter is reloaded from its buffer 
register. 

TMS 9940 INTERRUPT LOGIC 

The TMS 9940 has four external interrupts and twelve internal software interrupts. 

These are the four external interrupts: 
1) Reset. This has highest priority. 



2) A level 1 interrupt occurring at the INT1 pin. This has second highest priority. 

3) A Decrementer/Event Counter interrupt. This has third highest priority. 

4) A level 2 interrupt occurring at the INT2 pin. This has lowest priority. 

As described for the TMS 9900. you execute XOP instructions to generate software interrupts. X0P4 through X0P15 
are active. XOPO through X0P3 do not exist on the TMS 9940. 

TMS 9940 interrupt vectors, together with a complete TMS 9940 memory map. are illustrated in Figure 3-20. 

The actual interrupt acknowledge sequence for a TMS 9940 is identical to that which we have described for the TMS 
9900. 

TMS 9940 RESET 

You Reset the TMS 9940 by inputting a low signal at RST/PE (pin 20). This low signal must last for at least five 
clock cycles. A Reset resets to the contents of all pointer registers and all CRU configuration bits. Following a Reset 
level interrupt response begins — which means that read-only memory bytes through 3 provide the initial Program 
Counter and Word Pointer register contents, and therefore the address of the program which will be executed follow- 
ing the Reset. 
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Note that the TMS 9940. being a smaller and simpler system than the TMS 9900, can use elementary logic to generate 
an interrupt acknowledge. For the TMS 9900 we suggested an Address Bus decoding technique in order to create an 
interrupt acknowledge signal. For the TMS 9940 a CRU bit will do just fine. The following circuit is recommended by 
Texas Instruments: 
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A simple_p-type flip-flop has its D input connected to -I-5V. Every time an interrupt request pulse is input to the clock 
pin, the Q output will go low — generating a valid interrupt request at the TMS 9940. In order to acknowledge the in- 
terrupt and remove the interrup_t_request signal, you can output a low pulse via any of the P pins. This low pulse clears 
the D-type flip-flop and forces Q high again. 

PROGRAMMING A TMS 9940E ERASABLE, PROGRAMMABLE READ-ONLY MEMORY 

The TMS 9940E has a transparent quartz lid over the device in its dual in-line package. In order to erase the TMS 
9940E EPROM, you should expose it to a high-intensity ultraviolet light with a wavelength of 2537 angstroms. 

An intensity of 10 watt-seconds per square centimeter is recommended. 

After the TMS 9940E EPROM has been erased, all EPROM memory bits will be 0. 
These are the steps required in order to program a TMS 9940E EPROM: 

1) Reset the device. 

2) Apply the first data byte — to be stored in memory location 0000 to pins P24 through P31. Remember, P24 repre- 
sents the most significant bit of the byte, and P31 represents the least significant bit of the byte. 

3) Apply a 26-volt level to pin 20, the RST/PE pin. This being the first programming pulse, it resets the internal pro- 
gram memory address point at 0000 and writes the data byte at P24 through P31 into memory location 0. 

4) After at least 80 clock cycles, apply 26 volts to pin 37, INT2/PR0G, for 50 milliseconds while changing the data 
byte (step 5). 

5) Apply the next data byte to P24 through P31. At the high-to-low transition of PROG, the data will be written into 
the next location. 

6) Remove the 26 volts from pin 37 for a minimum of 50 clock cycles. Then apply 26V to pin 37 for 50 milliseconds. 

7) Return to Step 5 until all of program memory has been programmed. 

LOADING A PROGRAM INTO TMS 9940 READ/WRITE MEMORY 

You can load a program directly into TMS 9940 read/write memory via pins P24 (MSB) through P31 (LSB) for either the 
TMS 9940E or the TMS 9940M. Typically, this is done in order to load a small test program. The procedure for loading 
data into the TMS 9940 read/write memory is exactly as described in the previous section for loading data into EPROM, 
except: th e 26-v olt level is applied to pin 19, the TST pin, after the device has been reset by inputting a low signal to 
pin 20, the RST/PE pin; and the high pulses at PROG are logic '^' level rather than 26 volts. 

When you input data to a TMS 9940 read/write memory using the TEST pin and P24 through P31 , the address pointer 
is initialized to address 8300i q. The address keeps incrementing the high-to-low transition of each 50 millisecond pro- 
gramming pulse applied at pin 37. When you finally stop applying programming pulses, the last 16 bits of data input 
are interpreted as the beginning address for the program to be executed. This address may point to a read/write memo- 
ry location, or to a read/write memory location. That is to say, the test program may be in read/write memory, in read- 
only memory, or in both areas. 

THE TMS 9940 INSTRUCTION SET 

The TMS 9940 instruction set is Identical to the TMS 9900 instruction set, with these exceptions: 

1) The RSET, CKOF, CKON and LREX instructions have been deleted. That is, all the external instructions except 
IDLE. 
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2) The XOP instructions will not work with operands 0, 1 , 2, or 3. 

3) There are new DCA and DCS instructions that enable 8-bit binary-coded decimal arithmetic. 

Assuming that you start with two valid 8-bit binary-coded decimal operands, you can add these two 8-bit operands 
using normal binary addition. The result will be a meaningless 8-bit number; however, if you immediately execute the 
DCA instruction, this meaningless 8-bit number will be converted to a meaningful 8-bit, 2-BCD-digit number. 

DCS, likewise, allows you to perform 8-bit binary-coded decimal subtraction. Assuming that the subtrahend and mi- 
nuend are both valid 8-bit binary-coded decimal numbers, you perform a subtraction using binary arithmetic and you 
generate a meaningless 8-bit result. By executing the DCS instruction, you convert this meaningless 8-bit result into a 
valid 8-bit, 2-BCD-digit binary-coded decimal difference. 

The DCA and DCS instructions both generate in the low-order eight bits of the 16-bit word. 

For a discussion of decimal adjust logic in BCD addition or subtraction, see Volume 1, Chapter 3. 

The LIIM instruction loads a 2-bit interrupt masic into the two low-order bits of the Status register. 

Here are the instruction object codes used by the DCA, DCS, and LIIM instructions: 

Clock 
instruction Object Code Bytes Periods 

DCA r 00101 lOOOObbssss 2 7 

DCS r 001011 0001 bbssss 2 7 

LIIM n 00101 lOOIxxxxxnn 2 10 

The object code notation above conforms to that which we have described for Table 3-3. For the LIIM instruction, x 
represents "don't care" bits and n represents the two binary digits that get loaded into the two low-order Status 
register bits. 

THE TIM 9904 FOUR-PHASE CLOCK GENERATOR/DRIVER 

This part is also given the generic TTL name: the SN74LS362. The TIM 9904 provides TMS 9900 
microprocessors with the four clock signals: 4>1, < l>2, ^3, and 4>4. T hese are -t-12V MOS driver signals. In addi- 
tion, four complementary +5V clock signals, $1, 02, <{>3, and $4, are generated for use elsewhere in a TMS 
9900 microcomputer system. 

The TIM 9904 device may be driven by an external crystal, an external LC circuit, or a single external clock sig- 
nal. 

The TIM 9904 is manufactured using low-power Schottky technology; hence the 74LS part number. It is packaged as a 
20-pin DIP. All signals, other than the four MOS level clocks, are TTL-compatible. 

The TIM 9904 allows one asynchronous input signal to be syn chronized, via a D flip-flop, with the 4>3 signal. The syn- 
chronized signal is output, frequently to be used as a RESET input to the TMS 9900. 

Figure 3-23 illustrates TIM 9904 pins and signal assignments. 

The four clock si gnals . 4>1,4>2, 4>3, and $4, conform to Figure 3-3 . 01, 4>2, 4>3, and $4 are complements of 
4>1, 02. $3, and <I>4. 

A logic level input at D will be output at Q on the high-to-low transition of 4>3: 
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Pin Name 

4)1, $2, *3, 4>4 

$1, ^ *3, ^ 

D 

Q 

TANK1, TANK2 

XTAL1, XTAL2 

OSCIN 

OSCOUT 

Vccl. Vcc2, GND1, GND2 



Description Type 

+ 12V clocks to drive a TMS 9900 Output 

+ 5V clock complements Output 

Asynchronous control Input 

Synchronized control Output 
Crystal overtone controls 
External crystal connections 

External clock Input 

Clock with frequency 4$ Output 
Power, Ground 



Figure 3-23. TIM 9904 Signals and Pin Assignments 

OSCOUT provides a clock frequency four times that of the $ clocks. Its phase relationship to the 4> clocks may be 
illustrated as follows: 
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When an external quartz crystal is used to drive the TIM 9904, the following connections are required: 

TANK 1 

0.47 mH 



20 ohm to 75 ohm crystal, 
2 mw power dissipation. 
(May substitute a 
0.1 fiF capaciton) 




+5V 



OSCIN 



OSCIN must be tied to a high logic level for the internal clock logic to work properly. 

Required capacitor and inductance values are shown in the illustration above for a TMS 9900 microprocessor operating 
with its standard 3 MHz frequency The crystal must have a resonant frequency of 48 MHz. For 48 MHz operation, a 
third overtone crystal is used. 

For less precise timing, the quartz crystal may be replaced with a 0.1 yu,f capacitor. The LC-tuned circuit now estab- 
lishes the clock frequency according to the following equation: 

fosc = 1/(27rVLC) 

where L is the inductance, with units of Henries, and C is the capacitance with units of Farads. This includes the 
capacitance of the circuit into which the components are mounted. 

If an external clock signal is input, it must occur at OSCIN. The crystal connections XTAL1 and XTAL2 should be 
connected to Vcc ^s follows: 
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The clock input OSCIN must have a frequency which is four times the clock period frequency and has a 25% duty cycle. 
Thus, for a 3 MHz frequency, a 12 MHz signal must be input via OSCIN: 
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M 20.8ns [^ 



H 



r~\. 



In TMS 9900 microcomputer systems, the D input is used for an asynchronous reset; Q is output as a syn- 
chronous reset. This may be illustrated as follows: 




TMS 
9900 



RESET 



The illustration above shows recommended resistor and capacitor values. 

THE TMS 9901 PROGRAMMABLE SYSTEM INTERFACE (PSI) 

The TMS 9901 Programmable System Interface (PSI) is a special support part designed for the TMS 9900 series 
of microprocessors. This relatively primitive device uses 32 bits of the TMS 9900 CRU bit field to support 
parallel I/O and interrupt request logic. Programmable timer logic is also available. 

Figure 3-24 illustrates that part of general microcomputer system logic which has been implemented on the 
TMS 9901 PSI. 

The TMS 9901 PSI is packaged as a 40-pin DIP. It uses a single +5V power supply. All inputs and outputs are TTL-com- 
patible. The device is implemented using N-channel silicon gate MOS technology. 
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Figure 3-24. Logic of the TMS 9901 Programmable System Interface 
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Pin Name 




Description 

CRU data output 

CRU data input 

CRU data input strobe 

I/O data 

External interrupt requests 

Inten-upt request to CPU 

Inten-upt priority designation 

Chip Enable 

CRU bit select 

Chip reset 

Synchronizing clock signal 

Power, Ground reference 



Type 

Output 

Input 

Input 

Input or Output 

Input 

Output 

Output 

Input 

Input 

Input 

Input 



Figure 3-25. TMS 9901 Programmable System Interface Signals and Pin Assignments 

In the illustration above. Address lines have been numbered using our standard notation, whereby A14 is the highest- 
order address line and AO is the lowest-order address line. This is the opposite of Texas Instruments' notation. The CRU 
select lines are numbered according to Texas Instruments' notation and Figure 3-25. Therefore, 84 is connected to 
AO, and SO is connected to A4. 
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TMS 9901 PSI PINS AND SIGNALS 

The TMS 9901 pins and signals are illustrated in Figure 3-25. The signals which connect the TMS 9901 to a 
TMS 9900 series microprocessor are quite straightforward; they consist of the CRU and interrupt signals. 

The CRU signals include CRUIN, CRUOUT, and CRUCLK. 



The interrupt signals consist of INTREQ, ICO, IC1, IC2, and IC3. 

For a description of CRU and interrupt signals, refer back to our TMS 9900 discussion. 

Device select logic includes a chip enable input. CE, together with five CRU bit select pins, SO - S4.'CE and SO 
S4 will connect to the Address Bus as follows: 




In the illustration above. Address lines have been numbered using our standard notation, whereby A14 is the highest- 
order address line and AO is the lowest-order address line. This is the opposite of Texas Instruments' notation. The CRU 
select lines are numbered according to Texas Instruments' notation and Figure 3-25. Therefore, S4 is connected to 
AO, and SO is connected to A4. 



3-73 



Device select logic determines the CRU address space that will be reserved for the TMS 9901 PSI. This may be illustr- 
ated as follows: 
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The high -order three address lines, which we call A14, A13, and A12, are all zero during a CRU access, at which time 
MEMEN is inactive (high). Thus we decode address lines A1 1 through A5 to select a particular TMS 9901 device. 

Since the TMS 9980 uses the Address Bus differently during a CRU operation. TMS 9901 device select logic would 
connect to the Address Bus in a different way. The CRU bit select lines SO - S 4 would b e tied to lines A5 - A1 ; device 
select logic would decode lines A1 1 - A6; and lines A13 and A12, along with MEMEN, would indicate a CRU access. 
We illustrate this as follows: 
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inactive, indicate a 

CRU address 

<& is a synchronizin£_clock signal used to time data output and to sample interrup ts. 3 > is the complement of $3. For 
the TMS 9900, ^3 is generated by the TMS 9904. The TMS 9980 outputs $3 directly. 

The best way of understanding the interface between a TMS 9901 and external logic is to look at functions per- 
formed, as illustrated in Figure 3-26. 
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Figure 3-26. IMS 9901 PSI General Data Flows and CRU Bit Assignments 
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From the programmer's viewpoint, a TMS 9901 looks like 32 contiguous CRU bits. Thus, you will access any part of a 
TMS 9901 device's logic using CRU input and output instructions. 

As you read through the TMS 9901 description that follows, you should bear in mind the power of multi-bit CRU 
load and store instructions as they apply to TMS 9901 architecture. A single instruction transferring an appropri- 
ate bit pattern can frequently perform multiple control and data transfer operations. 

The manner in which CRU bits are used by the TMS 9901 is not straightforward. This is because CRU bits share 
functions and pins. Functions and pins are shared in different ways. 

Let us first look at pin connections. CRU bits 1 -6 connect to pins INT1 - INT6; thus, in interrupt mode each of these CRU 
bits has its own dedicated input pin. 

CRU bits 7-15 share nine input or output pins with CRU bits 23-31. CRU bits share pins as follows: 



Device Pins 



31 


7 


30 


8 


29 


9 


28 


10 


27 


11 


26 


12 


25 


13 


24 


14 


23 


15 



34 



33 



32 



31 



30 



29 



28 



27 



23 



These CRU bits support interrupt logic 
These CRU bits are dedicated to data I/O 



Each of the CRU bits shown above shares a pin with another CRU bit. That is to say, within the illustrated CRU address 
range, there are two CRU bits which will access the same pin, although each CRU bit performs a different operation. 
Thus you use the same pin in one of two different ways, using a bit address to select one operation. This may be illustr- 
ated as follows: 




if you select CRU bit 27, 
Pin 30 supports data I/O 



If you select CRU bit 1 1, 

and interrupt mode. 

Pin 30 serves as an 

interrupt request input 

CRU bits 16-22 connect to parallel I/O pins. These bit addresses are not shared with any other TMS 9901 functions. 

CRU bit is a select bit that is not connected to any pin. A 1 written into this bit causes bits 1-1 5 to support real- 
time clock logic. A written into CRU bitO selects interrupt logic. When CRU clock logic is selected, bits 1-14 function 
as two 14-bit real-time Clock Buffer registers — :one a read-only register, the other write-only. Real-time clock logic is 
separate from, and operates simultaneously with, and/or parallel I/O logic. That is to say, the process of selecting real- 
time clock logic does not disable any other logic. The select bit merely chooses which registers CRU addresses will ac- 
cess, rather than enabling or disabling any operations. 

TMS 9901 PSI INTERRUPT LOGIC 

The easiest place to start understanding the TMS 9901 is at its interrupt logic. 

External logic can input data to CRU bits 1-15 via their connected pins. These input data signals will be in- 
terpreted as interrupt requests if interrupts are enabled. If interrupts are disabled, then these CRU bits act 
simply as data input. 
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You access interrupt logic through the CRU when the select bit, CRU bit 0, contains a 0. 

CRU bit addresses 1-1 5 each access separate read-only and write-only locations. The read-only location stores the sig- 
nal level input at the attached pin. The write-only location accesses an interrupt mask bit. This may be illustrated as 
follows: 



CRU Bit N 
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\^ 



{* 



Write- 
Only 
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Read- 
only 
Data 
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Signals arriving at pins connected to CRU bits 1-15 are immediately reflected by CRU bit contents: 
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Data 
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I I 

A low level (that is, a bit) is interpreted as an interrupt request. The interrupt request is passed on to the mask bit. if 
the mask bit contains 1, the interrupt is enabled and the interrupt request is passed on: 
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If the mask bit is 0, the interrupt request is disabled and therefore denied: 
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High 



3-77 



Quite apart from interrupt logic, the CPU can at any time read the contents of one or more CRU bits in the address 
range 1-15. Here are some instructions that may access CRU bits 1-15 in various ways: 

LI R12,PSI4-1 LOAD CRU BASE ADDRESS INTO R12 

LI RI.MASK LOAD INTERRUPT MASK BITS INTO R1 

LDCR R1,15 OUTPUT TO WRITE-ONLY MASK LOCATIONS 



STCR 



R2,15 



INPUT CRU BITS 1 THROUGH 15 AS DATA TO R2 



For some randomly selected data levels, CRU bits 1-15 may be illustrated as follows: 



1 Bits Pass on 
Interrupt Requests' 
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110 
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13 1 
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15 1 



If one or mor e CRU bit 's interrupt requests are low, and the corresponding mask bit is 1 , then interrupt priority encoder 
logic outputs INTREQ low. Simultaneously, the level of the active interrupt request which has highest priority is iden- 
tified via ICO - IC3. 



INT1, input to CRU bit 1, has highest priority; 
INT15, input to CRU bit 15, has lowest priority. 

The levels at ICO - IC3 are maintained until the interrupt request signal is removed at the external pin, or the interrupt 
mask bit for the level is reset to 0. 

TMS 9901 PSI DATA INPUT AND OUTPUT 

You can use CRU I/O instructions to input, output, or test external data at CRU bits 16-31. Data is output from 
the CPU to the TMS 9901 via CRUOUT; it is input from the TMS 9901 to the CPU via CRUIN. Bits are addressed via SO - 
S4, as we have already described. 

Following a reset, pins connected to CRU bits 16-31 are in input mode. In this mode, external logic can assert high 
or low levels at connected pins, in which case one or two CRU bits will be affected: a signal in put to PO - P6 wil l gener- 
ate data in CRU bits 1 6-22; if interrupt mode is selected (by a in CRU bit 0), a signal input to INT7/P1 5-INT1 5/P7 will 
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generate data in two CRU bits, one in the CRU bit range 7-1 5, the other in CRU bit range 31-23. In interrupt mode, if 
the CPU inputs data from CRU bits 7-1 5 or 31 -23, then it will input the same data, but in reverse order. This may 
be illustrated as follows: 



LI 
STCR 



R12,PSI + 7 
R1,9 



0196,^ Loaded into R1 
16 



LI 
STCR 



R12,PSI + 23 
R1,9 



00D3^^ Loaded into R1 
16 
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Note that, as in all CRU transfers, the first CRU bit transferred goes to the least significant bit position of the destination 
register. 

As soon as the CPU outputs data to any bit capable of supporting data output, the I/O logic associated with this 
bit is put into output mode. In this nnode, a pin will output a voltage level reflecting data in the corresponding CRU bit. 
External logic cannot input data to a CRU bit that is in output mode; in fact, driving input currents into an output pin 
may damage the TMS 9901. 

Once a CRU bit has been placed in output mode, it remains in output mode until the TMS 9901 is reset. That is to 
say, you cannot selectively return CRU bits from output mode to input mode. However, you can always read output bits 
back to the CPU; that is, although external logic must never attempt to input to a pin that is in output mode, the 
CPU can always read the contents of any I/O bit, whether it is an input or an output. 

You cannot output data via CRU bits 7-15, even though these bits are connected to the same pins as CRU bits 31-23. 
When you output data to CRU bits 7-15, the data is routed to one of two write-only locations, depending on the con- 
tents of CRU bit 0: if the select bit is 0, the data goes to interrupt mask bits 7-15; if clock mode is selected (CRU bit 
contains 1), the data goes to the Clock Load Buffer register (bits 7-14) and RST2 (bit 15). 

In interrupt mode you can input external data from CRU bits 1 -6. Once again, you cannot output data via these CRU bit 
addresses, since any data output will be routed to corresponding interrupt mask bits or Clock Load Buffer bits. 
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TMS 9901 REAL-TIME CLOCK LOGIC 

If you write a 1 into CRU bit of a T1VIS 9901 device, then CRU bits 1-14 are used as two 14-bit Cloclc buffers, 

which may be illustrated as follows: 

1 2 3 4 5 6 7 8 9 10 11 12 13 14 -^- CRU Bit Number 
CRUOUT ^>| Clock Load Buffer 
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Clock Read Buffer 



Besides these two buffers, real-tinne Clocl< logic contains a decrementing register which we call the Clock 
Counter register. The CPU loads the Clock Counter register via the Clock Load Buffer, and reads the Counter contents 
via the Clock Read Buffer. We illustrate this in the following way: 
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The Clock Counter register decrements continuously as long as the TIVIS 9901 is powered up. This will cause no 
problems as long as the clock interrupt is disabled. 

When you write any non-zero value into the Clock Load Buffer (CRU bits 1-14), the Clock Counter register 
starts decrementing fronn that value. A decrement occurs once every 64 4) clock pulses. Thus, with a 3 MHz clock, a 
decrement occurs once every 21.3 microseconds. When the CRU Clock Counter register decrements to 0, an inter- 
rupt request is generated, the previously output starting value is reloaded, and the clock starts to decrement 
again. Thus, with a 21.3-microsecond time interval between decrements, the maximum time interval between inter- 
rupt requests will be 249 milliseconds. 



An enabled clock interrupt req uest causes INTREQ to be output low, together with a level 3 interrupt identified 
via ICO - IC3. That is to say, the INT3 external interrupt and the Cloc k logic sh are the same interrupt level and interrupt 
mask bit. in clock mode, CRU bit 1 5 is used to record the state of the INTREQ signal. Thus, if interrupt requests are dis- 
abled, the CPU program can check for a time-out by testing the level at CRU bit 1 5. This bit will be low i f no time-out 
has occurred, and it will be high if a time-out has occurred; thus this bit is the complement of INTREQ. 

Following a CRU real-time clock interrupt rejquest, you must write into interrupt mask bit 3 in order to clear the 
interrupt request. You can write a or a 1 into the interrupt mask bit. Normally, you will write a 1 in order to keep in- 
terrupts enabled. Writing a will clear any active real-time clock interrupt request, and will simultaneously disable 
further real-time clock interrupt requests. 

The Clock Read Buffer register contents do not change as long as the TMS 9901 is in clock mode. This charac- 
teristic insures that the Clock Read Buffer will hold a stable value while the CPU is reading it -^ even though the Clock 
Counter may decrement during the read operation. 
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Either of the following two events will cause the Clock Counter contents to transfer to the Clock Read Buffer: 

• The <I> pulse which causes the Clock Counter to decrement. 

• An exit from clock mode. 

Thus, the Clock Read Buffer register is updated whenever the TMS 9901 leaves clock mode, and every time the 
Clock Counter decrements outside of clock mode. 

Beware — even if CRU bit contams a 1 , the TMS 9901 will exit clock mode for as long as it sees a 1 on select line SO; 
this will happen whether or not CE is active. Thus the Clock Read Buffer will not hold the same value indefinitely 
just because the TMS 9901 select bit is set. The PSI will leave clock mode whenever the CPU reads to or writes from 
CRU bits 1 6-31 , or if any device accesses a memory address with a 1 on the address line connected to SO (A4 in a TMS 
9900 system). 

The logic controlling clock mode and the Clock Read Buffer may be illustrated as follows: 
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This logic summarizes our discussion above. There are two important things to note about clock mode and Clock Read 
Buffer update. First, you cannot inadvertently exit clock mode while you are reading the Clock Read Buffer, since you 
access it as CRU bits 1-14. Second, you cannot enter clock mode solely by accessing CRU bits 0-15; SO changes clock 
mode only when the select bit is 1 (clock mode selected). 

In order to read the most recent Clock Counter value, you must do two things: 

• Exit clock mode so the Clock Read Buffer will receive the current Clock Counter contents. 

• Enter clock mode so the Clock Read Buffer will be stable during the read itself. 

Here is the appropriate instruction sequence: 

LI R12,PSI+1 LOAD PSI CRU BASE ADDRESS 

SBZ -1 EXIT CLOCK MODE TO UPDATE READ BUFFER 

SBO -1 ENTER CLOCK MODE TO STABILIZE READ BUFFER 

STCR R1,14 READ 14-BIT CLOCK READ BUFFER 

TMS 9901 RESET LOGIC 

You can reset a TMS 9901 in one of two ways: 



1) By inputting a low signal at RST1. 

2) By using a programmed reset via RST2, a CRU bit. 

In order to use RST1, a low level must be input at this pin for at least two clock periods. 

You can reset the TMS 9 901 u nder program control only when clock mode is selected (CRU bit is 0). At this time, 
writing a to CRU bit 1 5 (RST2) causes the device to be reset. Thus, the following instruction sequence causes a TMS 
9901 device reset: 

LOAD PSI CRU BASE ADDRESS 
ENTER CLOCK MODE 
RESET PS! 



LI 


R12,PSI 


SBO 





SBZ 


15 



When the TMS 9901 is reset, the INTREQ signal is output high, ICO through 1C3 are output low, all interrupt requests 
are disabled, and all I/O CRU bits are placed in input mode. 



3-81 



THE TMS9902 ASYNCHRONOUS COMMUNICATIONS CONTROLLER 

The TMS9902 microprocessor family includes two serial I/O parts. The TMS9902 is a simple, asynchronous 
communications device; the TMS9903 is a more powerful, recently introduced multifunction device. Both of 
these parts are peculiar to the TMS9900 since they communicate with the CPU via its CRU logic. The two parts 
are also pin-compatible; that is, the same 20-pin socket can hold either the TMS9902 (an 18-pin part) or the 
TMS9903. 

The TMS9902, which we are about to describe, offers asynchronous I/O capabilities comparable with those of 
parts which we describe in Volume 3. The TMS9902 lacks some features which other parts offer: 

1 ) There are no external clocking signals for received or transmitted data. Receive and transmit rates are computed by 
logic internal to the TMS9902. 

2) There is a single interrupt request which has no accompanying status output lines. Thus interrupt service routines 
must interrogate status in order to correctly service the interrupt. 

3) The TMS9902 has only three Modem control lines and no other lines for handshaking with peripheral logic. 

One advantage of the TMS9902 is that it occupies very little board space. It is an 18-pin part, the smallest serial 
I/O controller on the market. It requires less surrounding logic because it uses the system clock for its time base, and 
because it provides almost no external status or handshake lines. 

Another advantage of the TMS9902, when compared to other serial I/O parts, is the presence of real-time clock logic. 
Anyone who has worked with serial I/O logic will appreciate the ability to generate interrupt requests at fixed time in- 
tervals. 

The TMS9902 is fabricated using NMOS technology. It is packaged as an 18-pin DIP and requires a single +5\/ power 
supply. All signals are TTL-level compatible. 

TMS9902 ACC PINS AND SIGNAL ASSIGNMENTS 

TMS9902 pins and signal assignments are illustrated in Figure 3-27. 

those of pins 1 through 9 and 12 through 20 of the TMS9903. 



These signal assignments are the same as 
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Figure 3-27. TMS9902 Asynchronous Communications Controller Pins and Signal Assignments 
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Table 3-9. ■TMS9902 Control and Status Register Bit Interpretations 



CONTROL REGISTER (WRITE) 


CRU/REGISTER 
BIT NUMBER 


STATUS REGISTER (READ) 


Device Reset (write 1 or 0) 


31 


Any interrupt pending* 


- 


30 


One or more of control bits 1 7, 14, 1 3, 1 2, or 1 1 set to 
1» 


- 


29 


DSR or CTS input level change detected. Reset by writ- 
ing 1 orOto CRUbit 21. 


- 


28 


Complement of CTS input level 


- 


27 


Complement of DSR input level 


- 


26 


Complement of RTS output level 


- 


25 


Timer time out*. Reset by writing 1 or to CRU bit 20. 


- 


24 


Timer overrun error*. Reset by writing 1 or to CRU bit 
20. 


- 


23 


Transmit Shift register empty*. Automatic reset. 


- 


22 


Transmit buffer empty*. Reset by writing to high-order 
Transmit buffer bit. 


Enable interrupts on DSR or CTS input level change 
(1 = enable, = disable) 


21 


Receive buffer loaded*. Reset by writing 1 or to CRU 
bit 18. 


Enable timer interrupts 
(1 = enable, = disable) 


20 


DSR or CTS input level change interrupt pending*. Reset 
by writing 1 or to CRU bit 21. 


Enable transmitter interrupts 
(1 = enable, = disable) 


19 


Timer interrupt pending*. Reset by writing 1 or to CRU 
bit 20. 


Enable receive interrupts 
(1 = enable, = disable) 


18 


— 


Transmit Break 

(1 = enable, = disable) 


17 


Transmit interrupt pending*. Reset either by writing to 
CRU bit 1 9 or by writing to high-order Transmit buffer bit. 


Enable transmit logic 
(Complement of RTS output) 


16 


Receive interrupt pending*. Reset by writing 1 or to 
CRU bit 1 8. 


Test mode select 

(1 = Test mode, = normal operation) 


15 


RxD input level 


Write to Parameter register 


14 


Receive start bit detected*. Reset automatically at end 
of received character. 


Write to Timer register 


13 


Receive first data bit detected*. Reset automatically at 
end of received character. 


Write to Receive Data Rate register 


12 


Receive framing error detected*. Reset automatically by 
error free received character. 


Write to Transmit Data Rate register 


11 


Receive overrun error detected*. Reset automatically by 
error-free received character. 


/ 


10 


Receive parity error detected* Reset automatically by 
error-free received character. 


, 


9 
8 


Any receive error detected.' Reset automatically when 
Status register bits 12, 11, and 1 are all 0. 
\ 


Receive Data Rate register 1 1 
or < 1 

Transmit Data Rate register Parameter register, 1 
Timer register, / 
or Transmit buffer | 

\ V 


7 
6 


) 


5 
4 
3 
2 
1 



1 


*1 = "true" condition. = "false" condition. 1 
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Signals that connect the TMS9902 to a TMS9900 series microprocessor include the three CRU signals CRUIN, 
CRUOUT, and CRUCLK, together with device select logic signals CE and S0-S4. The TMS9902 uses these sig- 
nals exactly as described for the TMS9901. CE must be low for the TMS9902 to be selected; if the TMS9902 is 
selected, then data transfers occur via the CRUIN or CRUOUT lines. S0-S4 identify the CRU bit within the selected 
TMS9902. Table 3-9 summarizes the way in which the TMS9902 assigns its 32 CRU bit addresses for read and 
write operations. 

DSR, RTS, and CTS are standard handshaking control signals for communications devices. 

DSR is a general purpose input signal; its level is reported in Status register bit 27. Yo u can program DSR to generate 
an interrupt request when it makes a high-to-low or low-to-high transition. However, DSR plays no part in enabling 
either transmit or receive logic. 

The TMS9 902 outputs RTS low while transmit logic is enabled. But the transmitter will not actually start transmitting 
data until CTS is input low. 

In a standard asynchronous protocol system, TMS9902 transmit logic will output RTS low and sometime later recei ve a 
low CTS input — at which time it will actually start transmitting data. But if TMS9902 transmit logic finds CTS low 
when it outputs RTS low, it will start transmitting immediately. 

For a discussion of Modem handshaking control signals, see Volume 1, Chapter 5. 

Serial data is input via RxD_and output via TxD. External logic does not provide signals that clock the serial input 
or output data. Instead, the <l> synchronizing clock input signal is used to derive data transmit or receive rates. Usually, 
<I> will be the TIM9904 clock output <I>3 (the complement of CPU clock 03). However, you may use any clock signal that 
satisfies the timing requirements given in the TMS9902 data sheet at the end of this chapter. 

TMS9902 DATA TRANSFER AND CONTROL 

The various addressable locations within the TMS9902 are summarized in Figure 3-28. 

When you write to CRU bits 31 through 1 1 you will always access the Control register; when you read these 
bits you will access the Status register. CRU bits 10 and 9 are also read-only status flags. 

CRU bits through 7, on a read, always access the Receive buffer; but via CRU bits through 1 you can send 
data to a variety of write-only locations. 



TMS9902 
REGISTER 
ADDRESSING 



The Control register contains four address bits, each of which corresponds to one of the write-only 
locations. When an address bit is set to 1, the associated write-only register will receive 
data output via CRU bits through 10. If more than one write-only location is selected, then 
the select priorities shown in Table 3-10 apply. The Transmit Buffer is selected when all 
four address bits contain 0. If any address bit is set to 1, Status register bit 30 will also contain 1. 

When you write to the high-order (highest numbered) bit of the Parameter register, the Timer register, or the 
Receive Rate register, you automatically reset that location's address bit in the Control register. 

Table 3-10. TMS9902 Write-Only Register Select Scheme 



CRU Output Bit 


Addressed Location 


CRU Bits in 
Location 


14 


13 


12 


11 


1 






X 

1 





X 
X 
1 

X* 



X 
X 
X* 

1 




Parameter register 
Timer register 
Receive Rate register 
Transmit Rate register 
Transmit buffer 


7-0 

7-0 

10-0 

10-0 

7-0 


"X" means "does not matter" 

* If both bits 1 1 and 1 2 are set to 1, data will be written to both Rate 
registers at the same time. 



Following a device reset, all write-only location address bits in the Control register are 

set to 1. This allows you to write data to registers in the priority order shown in Table 3-10 
during the device initialization process, without having to reset individual address bits. Thus 
the initialization process will consist of these steps; 

1) Reset the TMS9902 by writing to Control register bit 31. 

2) Write to the Parameter register. 



TMS9902 DEVICE 
INITIALIZATION 
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3) Write to the Interval Timer register. 

4) Write to the Receive Data Rate and Transmit Data Rate registers. 

5) Write to the Control register and Transmit buffer. 




CPU 

Interface 

Logic 



o 



:> 






o 



c 



v 



Timer 
Register 



Timer 
Logic 



Transmit 
Logic 



Transmit 
Buffer 



o 



Transmjt Rate 
Register 



Status Register 



Control Register 



P aramete r 
Register 



Receive Rate 
Register 



Receive 
Buffer 



2 



RTS 



Transmit 
Register 



TxD 



Receive 
Register 



RxD 



Receive 
Logic 



DSR 



Figure 3-28. TMS9902 Functional Logic 



Texas Instruments' literature suggests an initialization instruction sequence such as the following: 

INITIALIZE CRU BASE ADDRESS IN R12 
RESET COMMAND 

LOAD PARAMETER AND RESET BIT 14 
LOAD INTERVAL AND RESET BIT 13 
LOAD RECEIVE RATE AND RESET BIT 12 
LOAD TRANSMIT RATE AND RESET BIT 1 1 



LI 


R12,CRUBS 


SBO 


31 


LDCR 


@CNTRL,8 


LDCR 


@INTVL,8 


LDCR 


@RDR.11 


LDCR 


@XDR,12 
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In the sequence above, CRUBS represents the base address for the 32 CRU bits in the TMS9902. Four memory loca- 
tions — labeled CNTRL, INTVL, RDR. and XDR — hold the values to be loaded into the write-only locations. Since CRU 
bit 1 1 is not reset automatically, the instruction which writes to the Transmit Data Rate register writes 1 2 bits, the high- 
order bit being a for CRU bit 11. 

Let us now examine Control register bits in detail. 



Control register bits may be divided into interrupt enable/disable bits, write-only location address 
bits, the reset control, and the test mode control. 

The test mode control (bit 15) is usually left a t 0; this causes normal ope ratio ns to occur. When 
you set the test mode control bit t o 1 , RTS is internally connected to CTS and RxD is inter- 
nally connected to TxD. Also, DSR is held low internally and the interval timer operates at 32 
times its normal rate. You will operate the TMS9902 in this condition only when testing its logic. 

You reset the TMS9902 by writing either a or a 1 to Control register bit 31. 

You will usually begin every event sequence with a Reset. The following instructions constitute 
TMS9902 resets: 



TMS9902 
CONTROL 
REGISTER 



TMS9902 
TEST MODE 



Li 
SBO 



R12,ACC 
31 



LI 
SBZ 



R12,ACC 
31 



TMS9902 
RESET 



ACC is a label identifying CRU bit (the CRU base address) for the TMS9902. 
When the TMS9902 is reset, the following events occur: 

1) All interrupts are disabled. 

2) RTS is output high; this is the inactive state for RTS. 

3) Control register bits 11, 12, 13, and 14 are set to 1. All other Control register bits are reset to 0. 

The TMS9902 should not be accessed for a minimum of eleven <l> clock cycles following the reset command. 

There are four interrupt enable control bits. They enable interrupts when set to 1 and disable 
interrupts when reset to 0. 



TMS9902 

INTERRUPT 

ENABLE 



Control bit 21 enables CTS and DSR input signal level change interrupt requests. 

Control bit 20 enables timer time out interrupt requests. 

Control bit 19 enables Transmit buffer empty interrupt requests. 

Control bit 18 enables Receive buffer full interrupt requests. 

In each case a Status register bit is set to identify the condition that can generate an interrupt request. But the interrupt 
will not actually be requested unless the associated interrupt enable control bit has been set to 1. 



You acknowledge any interrupt other than a transmitter interrupt by writing to the interrupts TMS9902 
enable control bit. To acknowledge an interrupt and leave it enabled, rewrite a 1 to the inter- INTERRUPT 
rupt enable control bit. To acknowledge an interrupt and then disable it, write a to the inter- ACKNOWLEDGE 
rupt enable control bit. But remember, you must write either a or a 1 to the interrupt enable 
control bit, since this is the mechanism used to reset the status flags that identify the interrupting condition. 

You acknowledge a transmitter interrupt by writing to bit 7 of the Transmit buffer. If you write a to CRU bit 19, you 
will disable the interrupt, but you will not reset the status flag which was set by the emptying of the Transmit buffer. 

Control register bits 16 and 17 directly control two TMS9902 operations. 

Control register bit 16 is the com plement of the RTS outp ut. Y ou must write a 1 to this bit in orde r to s et RTS low. In 
order to enable transmit logic, RTS must be output low whil e CT S is being input low. You must leave RTS low while the 
transmitter is active. To disable the transmitter you raise RTS high again by writing to Control register bit 16; if 
transmit logic is part way through transmitting a character when you write a to Control register bit 16, then it will 
com plete transmitting the character — and the character in the Transmit buffer, if the buffer is full — before outputting 
RTS high. 



Transmit break logic is controlled via Control register bit 17. When you set this bit to 1. a TMS9902 

break (continuous low output) will be transmitted following the next underrun (that is. when both BREAK 
the Transmit register and Transmit buffer are empty). You must end the break by writing a to LOGIC 
Control register bit 17 before you can restart transmitting by writing new data to the Transmit * 
buffer. If you leave Control register bit 1 7 reset to 0. then following an underrun the transmitter will mark (output a con- 
tinuously high signal). You can end the mark at any time, and start transmitting a new message, by writing fresh data 
to the Transmit buffer. 
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TMS9902 

STATUS 

REGISTER 



TMS9902 

TRANSMITTER 

STATUS 



When the break control bit is set to 1, Status register bit 30 will also contain a 1. 
Let us now examine Status register bits; they may be grouped as follows: 

1) Signal level indicators 

2) Transmit operation status 

3) Receive operation status 

4) Timer logic 

5) Interrupt logic 

Status register bits 27 a nd 28 report the complement of the DSR and CTS input signal levels. Bit 26 reports the 
complement of the RTS output signal level. 

When the DSR or CTS input changes level, bit 29 is set. You reset bit 29 by writing to Control register bit 21. 

There are three transmit logic status bits. Bit 22 is set when the Transmit buffer is empty. The 
bit is reset when you next write data to the Transmit buffer. Bit 23 is set when the Transmit 
Shift register is empty; this is an underrun condition. Following an underrun, a break or a mark 
will be transmitted, depending on the level of Control register bit 17. Bit 30 of the Status register 
contains a 1 if any of the following Control register bits are set to 1: 

• Bit 17, the break control bit 

• Bits 14, 13, 12, and 11, the write-only, location address bits 

Thus Status register bit 30 will be set to 1 whenever Transmit buffer loading is disabled. 

For receive logic, bit 21 is set when the Receive buffer is full. The CPU resets this bit by writing to 
bit 18 of the Control register; usually the program will read the contents of the Receive buffer 
before resetting the flag bit. 

RxD, the serial data input line level, is reported at Status register bit 15. 

The start of each received character is identified by Status register bits 14 and 13. When the start bit has been 
detected. Status register bit 14 is set. One bit time later, when the first data bit is being detected. Status 
register bit 13 is set. These two bits remain set until the end of the character. They are reset when the last stop bit has 
been detected. 

Framing, overrun, and parity errors are reported by Status register bits 12, 11, and 10, respectively. These error 
status bits, once set, remain set until an error-free character is loaded into the Receive buffer 

If one or more of the three receive error conditions exist, then Status register bit 9 is set. 

There are two timer status bits. Whenever the timer times out. Status register bit 25 is set to 



TMS9902 
RECEIVER 
STATUS 



1. This bit must be reset by writing or 1 to Control register bit 20. If you do not do so before the 
next time out, then Status register bit 24 will be set, indicating a timer error. The timer error is 
also cleared by writing or 1 to Control register bit 20. 

The four interrupt generating conditions have associated status bits which are set following an interrupt request. 



TMS9902 

TIMER 

STATUS 



TMS9902 

INTERRUPT 

STATUS 



If the DSR or CTS input signal changes level, and the interrupt logic has been enabled, then 
Status register bit 20 is set at the time that an interrupt request is generated. 

If a time out occurs and timer interrupts have been enabled, then Status register bit 1 9 is 
set at the time an interrupt request occurs. 

When the Transmit buffer becomes empty, if transmitter interrupts have been enabled, then Status register bit 
17 is set at the time an interrupt request occurs. 

When the Receive buffer is full, if receive interrupts have been enabled, then Status register bit 16 is set at the 
time a receiver interrupt request is generated. 

If one or more of these interrupt requests are active, then Status register bit 31 is set. 

Interrupt status bits remain set until you reset either the status bit for the interrupting condition, or its interrupt enable 
bit in the Control register. In most cases, writing to the enable bit resets the status bit. 

For a Modem signal interrupt you must write to Control register bit 21 in order to acknowledge the interrupt, thus reset- 
ting the two Status register bits. 

For a timer interrupt you must write to Control register bit 20 to reset the interrupt. 

For a Transmit buffer empty interrupt you must write new data to the Transmit buffer in order to acknowledge the inter- 
rupt; specifically, you must write to bit 7 of the Transmit buffer. 
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For a Receive buffer full interrupt, you must write to Control register bit 18 in order to acknowledge the interrupt. 
Let us now examine Parameter register contents. 



After resetting the TMS9902, the next step is to identify subsequent operations by loading ap- 
propriate data into the Parameter register. Parameter register bits are interpreted as follows: 



TMS9902 

PARAIVIETER 

REGISTER 




Bit No. 
Parameter register 



5 -bit data words 
6-bit data words 
7 -bit data words 
8-bit data words 



- Divide ^ by 3 to generate CLK 

- Divide 4> by 4 to generate CLK 
■ No parity bit 

- No parity bit 

- Even parity bit 

- Odd parity bit 

- Select 1 'A stop bits 

- Select 2 stop bits 

- Select 1 stop bit 

- Select 1 stop bit 



TIVIS9902 INTERIMAL 
CLOCK SIGNAL 



The options presented by the Parameter register, as illustrated above, are self-evident, with 
the exception of Parameter register bit 3. This bit is used to generate an internal clock sig- 
nal, CLIC_Depending on the setting of Parameter register bit 3, the CLK frequency will be 
<t>/3 or <3>/4. CLK is then used to specify the time interval between bit sampling for serial 
data input or output, as well as thejnterval timer rate. The frequency of CLK should not be 
greater than 1.1 MHz; therefore if •!> is faster than 3.3 MHz, Parameter register bit 3 should 
be set to 1 . 

After loading appropriate data into the Parameter register, you must load the Transmit and Receive Data Rate registers 
in order to specify the time interval that will separate bit sampling. Data Rate register contents are interpreted as 
follows: 



TRANSIVIIT AND 
RECEIVE DATA 
RATE REGISTERS 




Bit No. 

Transmit or Receive Data Rate register 



Second scale factor (S). 

Can have any value in the range 1 (0000000011 

through 1023 (111111111) 

First scale factor (F). 

Can be or 1 . If F = 0, S should be > 4 
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The time interval separating serial bits transnnitted or received is given by the equation: 

tcLK X 2 X 8'^ X S 
For exannple, suppose the Receive Data Rate register contains 1 10001 1 1000. S = 568io and F = 1 : 



1 1 000 111000 




238i6 = 568io = S 
1 = F 



If CLK ="$/3, and'O = 3 MHz, then the serial data transfer rate will be: 

(1 X 106) -r (2 X 8 X 568) = 110.04 bits per second 
If F = 0, then the serial data transfer rate becomes: 

(1 X 106) -r (2 X 8 X 568) = 880.28 bits per second 

Table 3-1 1 shows sample Data Rate register values for standard Baud rates. The assumed ^ frequency produces very 
precise Baud rates; it is also within the recommended operating range of TMS9900 series parts. 



Table 3-1 1. Example of Data Rate Register Contents 
for Standard Baud Rates 



Frequency $ = 3.168 MHz 
Frequency CLK = $ -^ 3 = 1 .066 MHz 


Data Rate Register 
Contents 


Data Rate in 
Bits per Second 


Decimal 


Hexadecimal 


F 


S 








1 
1 
1 
1 


55 
110 
220 
440 
880 
220 
440 
600 
880 


037 
06E 
ODC 
1B8 
370 
4DC 
5B8 
658 
770 


9600 

4800 

2400 

1200 

600 

300 

150 

110 

75 


Date Rate = CLK -i- (2 x S^ x S) 1 



It is not strictly necessary to have data rates as precise as those we have shown in Table 3-1 1. 

The devices which receive data from the TMS9902 will determine how precise the transmit rate must be. 

TMS9902 Receive Logic resynchronizes itself with the beginning of each incoming character. It does this by starting its 
bit-time count at a high-to-low transition of RxD. When the TMS9902 has counted half a bit-time, it samples RxD; if the 
line is still low. Receive logic assumes a valid start bit is present. It then samples the. line at single-bit-time intervals 
after the first sample point, until a full cfiaracter has been received: 



Start 
bit 



Character 



Stop 
bit 



RxD 



Middle of start bit Is 

one-half bit time from 

this falling edge 



~Jj 



s. 



r~^ 



TMS9902 samples RxD at the middle of each bit 
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Because of this resynchronization, no skew errors will occur as long as the transmitted bit rate is within 4% of the 
TMS9902 Receive data rate. 

TMS9902 TRANSMIT OPERATIONS 

Let us now examine a serial data transmit event sequence as illustrated in Figure 3-29. 



a.— a) a 



O (5 



1 


ai 0> 
Q = 
x: 3= 
O a 


2 S 


V 






(0 


a.£ 


S" 


^ V,' 


nM 


!1! 


O cc 


O m 



-2 ^ 



L..±±..l.± • 



Transmit data 



Idle or Break 



hr\ ^ -ID, 



Transmit Buffer empty. 

Transmit Register empty, 

Break control bit = 



5 «^ 



One data 
character 



\ 



\ 



^ 



Move Transmit 
Buffer contents to 
Transmit register 



Output data to 
Transmit Buffer 



" CM 
B fM 
(0 ^ 

(A '3 



START 
BIT 



LSB 



LSB 
+ 1 



MSB 



o •- 
II II 



« (0 
(S (D 

55 5) 



Data Character 



.t; II 
o ^ 

55 5 



START 
BIT 



Figure 3-29. TMS9902 Character Transmit Event Sequence 

In this example, all operations will begin with a Reset. Remember, you reset the TMS9902 by writ- 
ing a or 1 toCRU bit 31. 

Next, output appropriate codes to the Control and Parameter registers and enable appropriate in- 
terrupts. 

Output Data Rate register settings. 

Output the first character to the Transmit Buffer register. 



TMS9902 

SERIAL 

TRANSMIT 

EVENT 

SEQUENCE 
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Transmit logic has now been initialized. You begin actual data transmission by setting RTS low. An appropriate in- 
itialization instruction sequence was given earlier. 

Setting RTS l ow enable s tran smit logic within the TMS 9902, but actual data transmission does not begin until e xtern al 
logic inputs CTS low. If CTS is already low when RTS is reset low, then data transmission will begin as soon as RTS is 
output low. 

When a character is transmitted, the Transmit buffer contents are moved to the Transmit register, at which time Status 
register bit 22 is set. If transmit interrupt logic has been enabled, an interrupt request will occur at this time and Status 
register bit 17 will be set. 

The character is transmitted as illustrated in Figure 3-29; options are specified in the Parameter register. As soon as 
the character's stop bit (or bits) has been transmitted, transmission of the next data character begins, provided the CPU 
has by this time loaded the next data character into the Transmit buffer. The CPU will normally have plenty of time to 
reload the Transmit buffer, since it takes a long time, in terms of instruction execution times, to transmit a character. 

Note that you must write to bit 7 of the Transmit buffer in order to reset the Transmit buffer empty flag. Thus even 
though the character length is less than 8 bits, you will always write 8 bits to the Transmit buffer. You right-adjust 
Transmit buffer characters; that is, bit of the Transmit buffer is always the least significant bit of the character. 

If transmit interrupts have been enabled, an interrupt request will occur when Status register bit 22 is set. The CPU will 
respond to the interrupt request by interrogating Status register bits to identify the nature of the interrupt. Upon 
detecting a 1 in bit 17, the CPU will output another data character. If transmit interrupt logic has not been enabled, 
then the CPU must periodically poll the Status register and output the next data character upon detecting bit 22 set to 
1. 



If the Transmit buffer is empty at the end of a data character transfer, then the TMS9902 TIVIS9902 
may transmit a Breaic (if Control register bit 17 is 1), or it may terminate operations and go BREAK 
into an idle state (if Control register bit 17 is 0). ^"^~^"^"~ 

The TMS9902 will transmit a Break if CTS is still low and Control register bit 17 is high. A Break is a continuous low 
level output via TxD. External logic interprets a Break as a signal indicating temporary suspension of data transfer. 

Break logic inhibits data transfers to the Transmit buffer. You must terminate a Break by resetting Control register 
bit 17 to 0, then loading the next data character into the Transmit buffer. 

TMS9902 transmit logic will enter an idle state if CTS is input high by external logic or if CTS is input low, but no new 
data is ready to transmit and break logic is off. During this idle state TxD will be held high (marking). 

The level of the RTS output is not affected by a change in the CTS input level. 

If CTS goes high during a transmit operation a nd yo u leave RTS output low, then as soon as CTS goes low again the 
transmitter will be re-enabled; but if you output RTS high by writing to Control register bit 1 6, then the CT S inp ut will 
be ig nored. In order to re-enable transmit logic you must output 1 to Control register bit 16, again settin g RT S low. If 
CTS is low a t this time, transmission will begin immediately; otherwise, transmission will begin as soon as CTS is input 
low — after RTS has again been output low. This may be illustrated as follows: 




Disable 

transmit 

logic; stop 

transmitting 

at end of character. 




Enable 
transmit 
logic; start 
transmitting 
again 



Stop transmitting at end of character 
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"\ 



Status register 
bit 14=1 



Status register 
bit 1 3 = 1 



(A 



+ CO 



Least significant bit 



Status register 

bits 1 4 and 1 3 both = ' 



Most significant bit 



Parity bit, if specified 



Stop bit(s) 



^> 



-I Status bit 
21 = 1 



v. 



SCO S 

* o a> 
09 3 n 

£.« 2- 



> 



\ 



\ 



Status register 
bits 21, 14, and 
13 all = 



\ 



\ 



\ 



r 
h- 



RESET 



Output Control register and 
Interrupt Enable register 
settings 

Output both Data Rate 
register settings 

(Send "Receive logic 
Ready" signal) 



\ 



/ 



/ 



/ 








TMS9902 RECEIVE OPERATIONS 

As soon as the TMS9902 is reset, receive logic is enabled. 

The TMS9902 outputs no "ready to receive" signal to external logic telling it when to start transmitting data to 
the TMS9902. You must create some such signal, since the Parameter register, interrupt flags, and Data Rate 
register must be initialized before external logic starts to input data; otherwise, the TMS9902 will not know how to in- 
terpret the serial data input. You have three options: 

1) You could use a CRU data bit (perhaps via a TMS9901 pin) for this purpose. 

2) You could use the RTS output for this purpose, provided transmit logic is not active. 

3) External logic could decode a TMS9902 Reset from the CE and S0-S4 pins, then, after some standard delay time, 
external logic could begin transmitting data to the TMS9902. For example. Reset could be used to trigger a one- 
shot whose output initialized data transfer to the TMS9902. 

It does not matter whether you do or do not create a "ready to receive" signal, receive logic within the TMS9902 will 
begin operating as soon as it detects a high-to-low transition on the RxD input. One half of a bit-time after the RxD 
transition. Status register bit 14 is set to 1. If RxD is high at this time, then Status register bit 14 is reset to and receive 
logic waits for the next high-to-low transition of RxD. If a true Start bit is present, however, then one bit-time after the 
setting of bit 14, Status register bit 13 is set to 1 and receive logic assumes that valid data is being input. 

Status register bits 14 and 13 are useful only for testing TMS9902 operations. For example, you can use them to verify 
the Receive data rate. These bits are not particularly useful in normal operation. 

As soon as a valid data character has been input, it is transmitted to the Receive buffer, and Status register bit 21 is set 
to 1 . If receive interrupt logic has been enabled. Status register bit 1 6 is set, and an interrupt request is generated. If in- 
terrupts have not been enabled, the CPU will poll the Status register in order to detect a data character which must be 
read. 



TMS9902 

ERROR 

FLAGS 



There are a number of error conditions that can occur during a receive operation. 

If a valid Stop bit is not detected, the receive framing error status (bit 12) is set. 

If parity has been specified but incorrect parity is detected, then Status register bit 10 is set. 

If the CPU does not read a character in time (that is, before the next character is loaded into the 
Receive Buffer register), then a receive overrun error occurs and Status register bit 11 is set. 

Status register bit 9 is set when any receive error occurs. 

A receive error does not generate an interrupt request. The CPU must check the receive error status flags in order to 
find out if any error has occurred. This is normally a routine part of reading received data. 

TMS9902 INTERVAL TIMER OPERATIONS 

TMS9902 interval timer logic is quite straightforward. 

You must initialize the interval timer by loading a value into the Interval Timer register. You subsequently start the in- 
terval timer by resetting Control register bit 13 to 0. (Remember, this occurs automatically when you write into the 
high-order Timer register bit.) At this time the contents of the Interval Timer register are moved to interval timer logic, 
where they are decremented once every 64 internal clock cycles (CLK). Remember, a CLK cycle may be three or four 
times as long as a <I> cycle. When the interval timer decrements to 0, Status register bit 25 is set and an interrupt re- 
quest is generated if interval timer interrupt logic has been enabled. Immediately, the contents of the Interval Timer 
register are moved to interval timer logic and decrementing begins again. 

The CPU must reset Status register bit 25 before the next time out occurs; otherwise, when the next time out occurs, 
an error will be indicated. Status register bit 24 is set to indicate this error. 

The CPU can at any time reset the value in the Interval Timer register. However, it is impossible to read the contents of 
the interval timer on the fly; that is to say, there is no way in which the CPU can read the current decrementing value 
held within interval timer logic. 

TMS9902 TEST MODE 

In order to diagnose the TMS9902 on line you can put it into a test mode by writing 1 to Control register bit 1 5. 
In Test mode, the following occurs: 

1) CTS is connected inter nally to RTS; therefore, CTS will become true internally whenever RTS is output low, regard- 
less of the level at the CTS input pin. 

2) RxD is connected internally to TxD; therefore, whatever is transmitted and output via TxD will be received by 
receive logic, regardless of the level at the RxD input pin. 
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3) DSR is held low. 

4) The interval tinner decrements at 32 tinnes its normal rate. 

You can use the Tpst mode in order to check the TMS9902 when a TMS9900 microcomputer system would otherwise 
be idle. For example, during times of inactivity, you will frequently execute a "no operation" loop, waiting for an exter- 
nal interrupt. Instead of executing a "no operation" loop, you could execute a short program which puts the TI\/IS9902 
into Test mode, sends data to the device, and then checks received data to see if it is the same. 

TxD and RTS act as normal outputs during Test mode. Therefore, you might wish to disconnect these lines from exter- 
nal logic duri ng the execution of the test program. One way to do this would be to use an external CRU bit to disable 
TxD and RTS out; this bit would be set at the beginning of the Test mode program and reset before normal operations 
resumed. Disconnect logic would be basic AND logic: 



O 



TxD _ 

TEST MODE ' " " Transmitted Data 



RTS C I y 



Ready to Send 
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THE TMS9903 SYNCHRONOUS COMMUNICATIONS CONTROLLER 

The TMS9903 Synchronous Communications Controller is equivalent to the TMS9902 Asynchronous Com- 
munications Controller, which we have just described, with synchronous and SDLC capabilities added. 
Although the TMS9903 is referred to in Texas Instruments literature as a Synchronous Communications Con- 
troller, it also has asynchronous communications capabilities. 

Compared to devices described in Section C of Volume 3, you will find that the TMS9903 is a general purpose 
device of average capabilities. 

It is worth comparing the TMS9903 to serial I/O devices described in Section C of Volume 3, since these general pur- 
pose serial I/O devices can easily be included in a TMS9900 series microcomputer system in the place of a TMS9903. 

This description of the TMS9903 assumes that you understand synchronous, asynchronous, and SDLC pro- 
tocols. If you do not understand these protocols then see Volume 1, Chapter 5 for a description of synchronous and 
asynchronous protocols. For a description of SDLC protocol see Volume 3, Chapter CI. 

We describe the TMS9903 in this chapter, rather than Section Qof Volume 3, because the TMS9903 CPU interface 
uses the TMS9900 series Communications Register Unit (CRU) logic. 

The TMS9903 is manufactured using N-channel silicon gate MOS technology. It is packaged as a 20-pin DIP, making it 
the smallest synchronous controller chip on the market. All signals are TTL-level compatible. A single +5V power sup- 
ply is required. 

A TMS9903 FUNCTIONAL OVERVIEW 

Logic of the TMS9903 is illustrated functionally in Figure 3-31 . 

On the CPU interface the TMS9903 occupies 32 CRU bits. High numbered CRU bits write to the Control register, 
and are read from the Status register. Low numbered CRU bits form an internal Data Bus that is bidirectional and has 
variable width. Via this Data Bus the CPU may read data from the Receive buffer, or it may read one of three cyclical re- 
dundancy characters. The CPU may write to the Transmit buffer, the Parameter register, or one of the two Sync 
registers; it may also output data to be included in either of two cyclical redundancy characters. Thus, when program- 
ming a TMS9900 series microprocessor, you can visualize the TMS9903 32-blt CRU field as follows: 



Status Register 
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Transmit CRC 
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Figure 3-31. TMS9903 Synchronous Connnnunications Controller 
'Functional Logic 

As illustrated above, there are three cyclical redundancy checic characters which can be read from the 
TMS9903. 

Transmit and receive logic each connpute a cyclical redundancy character (under program control) for transmitted and 
received messages. 

In SDLC mode only, the cyclical redundancy character for a received frame is isolated by receive logic and held in a 
register out of which it can be read. 
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We will describe programming aspects of cyclical redundancy characters in more detail as the discussion of the 
TMS9903 proceeds. 

Transmit and receive logic are each buffered. Data is moved from the Transmit buffer to the Transmit Shift register, 
whence it is output serially via TxD. You have one character transmit time within which to write another character to 
the Transmit buffer, otherwise an underrun will occur. 

Characters are assembled by receive logic in the Receive Shift register; when assembled, they are transferred to the 
Receive buffer. You have one character receive time within which to read the contents of the Receive buffer, or else a 
receive overrun will occur. 

Data buffers within the TMS9903 are all nine bits wide; this gives you the option of appending a parity bit to 
any 8-bit character. The Status register is 23 bits wide, the Control register is 20 bits wide, and the Parameter register 
is 1 2 bits wide; these odd bit lengths cause no problems due to the nature of the CRU interface between the TMS9903 
and the TMS9900 series microprocessor. 

The Synci and Sync2 registers hold Sync characters; in certain protocols these two registers may hold special 
control characters. Transmit logic may output the contents of one or both of these registers at the beginning of a 
message and following an underrun. Receive logic uses the contents of the Synci register to detect Sync characters in 
a received data stream. 

You specify the number of data bits per character for received data via Parameter register bit settings. 

When receive logic is assembling characters in the Receive Shift register, it uses the bits-per-character specification 
that was in effect when the current character started to be assembled. If you change the bits-per-character specifica- 
tion, the change will be recognized on the next receive character boundary. 

The bits-per-character specification that you make in the Parameter register does not apply to transmit logic or 
the Synci and Sync2 registers. For these three registers the number of data bits you write into the register 
defines the number of data bits which will be transmitted. The most recently loaded Sync register determines 
the character length for transmission of both Sync characters. 

For example, if you output 6-bit characters to these three registers, then 6-bit characters are assumed by transmit logic. 
Likewise, if you output 9-bit characters, then transmit logic will subsequently assume 9-bit Synci and Sync2 charac- 
ters. 

Synci and Sync2 registers should have the same bits-per-character specifications. However, you could, for example, 
output a 7-bit character to Synci and then a 5-bit character to Sync2. If you did, the device would transmit just the 
lower five bits of Synci and Sync2. You could still specify 7-bit characters to receive logic; each received character 
would be compared to all seven bits of Synci. The Sync character bit length need not be the same as the bits-per- 
character specification in the Parameter register or even the number of bits specified by loading the Transmit buffer. 

As with the Receiver, you can change the Transmit character length from character to character. As each character is 
shifted from the Transmit buffer to the Transmit Shift register, transmit logic attaches the bits-per-character specifica- 
tion to the data in the Transmit Shift register. Therefore if you subsequently change the number of bits per transmit 
character — namely, by loading a different-sized word into the Transmit buffer — it has no effect on the character 
already in the Transmit Shift register 

Although Texas Instruments literature describes the TMS9903 as supporting six different 
modes, in fact it supports three: Asynchronous, Synchronous, and SDLC/HDLC. 



TMS9903 
MODES 



Asynchronous and Synchronous mode capabilities are quite standard. 

In Synchronous mode you can approximate IBM standard Monosync or Bisync protocols. 

Asynchronous mode is well suited to RS-232C and RS-449 EIA standard protocols. 

The TMS9903 can be operated in a point-to-point SDLC or HDLC system; also, SDLC loop mode is supported. 

The TMS9903, like the TMS9902, has on-chip timer logic. 

TMS9903 PINS AND SIGNALS 

TMS9903 pins and signals are illustrated in Figure 3-32. Pins 1 through 9 and 12 through 20 are functionally 
equivalent to TMS9902 pins 1 through 18. 

On its CPU interface the TMS9903 has the same standard TMS9900 signals as the TMS9901 and 
the TMS9902. These include: 

1) The three standard CRU signals: CRUIN, CRUOUT, and CRUCLK. 

2) Five select lines (S0-S4) that address a 32-bit CRU field. 
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TMS9903 CPU 

INTERFACE 

SIGNALS 



3) CE, an enable signal which nnust be low for the CPU interface to be enabled. 

4) An input clock signal, nornnally connected to the TIM9904 4>3 clock. 

Refer to our earlier discussion of the TIVIS9901 for a description of CPU interfacing logic. 



IMT ^^^— ~— ^^ 




I / / . r-« tfl 


1 20 

2 19 


IN 1 ^W^ 


Vcc (+5v) 

-4 CF 


TxD ^t 




RxD 




3 18 


-^ * 


CRUIN -^- 




4 17 


"^ CRUCLK 


RTS '^- 




5 ™S ,6 


•^ SO 


CTS 




6 9903 15 


■^ SI 


DSR 




7 14 


<^ S2 


CRUOUT 




8 13 

9 12 


■^ S3 

-^ S4 


((jND; Vss 




TxC 

Pin Name 




10 11 


^ RxC 

Type 


Description 


CRUIN 


Data output to CPU 


Output, tristate 


CRUOUT 


Data input from CPU 


Input, tristate 


CRUCLK 


CPU data transfer clock 


Input 


S0-S4 


CRU bit address 


Input 


CE 


Device enable 


Input 


TxD 


Serial data out 


Output 


TxC 


Serial data output clock 


Input 


RxD 


Serial data in 


Input 


RxC 


Serial data input clock 


Input 


RTS 


Request to send indicator 


Output 


CTS 


Clear to send indicator 


Input 


DSR 


Data set ready indicator 


Input 


$ 


System clock 


Input 


INT 


Interrupt request to CPU 


Output 


VCC' Vss 


Power, ground reference 





Figure 3-32. TMS9903 Synchronous Connnnunications Controller 
Pins and Signal Assignnnents 



TMS9903 
SERIAL I/O 
SIGNALS 



Let us now examine transmit and receive logic signals. 

Serial data is output by tran smit logic via TxD, as clocked by TxC. Data is transmitted on 
high-to-low transitions of TxC. 

RTS and CTS are two Mod em c ontrol signals associated with transmit logic. In order to 

transmit data you must input CTS low while transmit logic is enabled. You have the option of connecting RTS to 
transmit enable logic. If you do, RTS will be output low while trans mit lo gic is enabled and it will be output high while 
trans mit logic is disabled. You also have the option of selecting the RTS output level under program control, in which 
case RTS is disconnected from transmit enable logic. 

Receive logic receives data via RxD as clocked by RxC. Data is sampled on low-to-high transitions of RxC. 

DSR is s how n in Figure 3-31 as a receive logic Modem input signal; in reality it is an unassigned input control sig- 

nal. The DSR signal level is reported in a Status register bit, and can generate an interrupt whenever it changes state. 
DSR does not contribute to receive enable logic. 

TMS9903 PROGRAMMABLE REGISTERS 

The two principal programmable registers of the TMS9903 are the Control and Status registers. We refer to 
these as "principal" registers because they are automatically accessed by high numbered CRU bits on any CRU access. 
Low numbered CRU bits transfer data to or from a variety of addressable locations, as specified by Control register bit 
settings. 
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Table 3-12. TMS9903 Synchronous Communications Controller CRU Bit Assignments 
When Writing to the TMS9903 



m CD 
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MODE 






U 

Z 
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u z 
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>- 
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(0 


FUNCTION 




31 


X 


X 


X 


1 or = Reset device. 




30 


X 


X 


X 


1 = Clear transmitter. = Clear receiver. {In each case interrupts are disabled). 




29 


X 


X 


X 


1 = Clear transmit CRC register. = Clear receive CRC register. (CRC register is reset to 0). 




28 




X 


X 


1 = Delete received Synci characters (in Bisync mode only). 
1 = Inhibit transmit logic's zero bit insertion. 




27 




X 


X 


1 = Load data at CRU bits - 9 into Sync2 register. 




26 




X 


X 


1 = Load data at CRU bits - 9 into Synci register (only for versions of Synchronous mode that use Synci register). 

1 = Read received check character via CRU bits 0-15. 

= Reset Status register CRU bits 13 (Check Character Buffer full), 1 2 (Check Character overrun) and 1 (Zero insert detect error). 




25 


X 


X 


X 


1 = Load data output to CRU bits - 8 into Transmit buffer, and update the transmit CRC. Select the transmit CRC to be read via CRU bits - 
= Reset Status register bits 22 and 1 7. 


15. 


24 


X 


X 


X 


1 = Update the transmit CRC with the next output to CRU bits - 9. Read transmit CRC at CRU bits 0-15. 




23 


X 


X 


X 


1 = Transmit break (low level output) during underrun. Reset this bit to before loading new data into Transmit buffer to end underrun. 

Specify synchronous modes' underrun options. (See textXGeneral and Bisync only). 

1 = Transmit Sync2 register contents following an underrun. (Typically 7Fig for an HDLC abort). 








X 


X 


= Abort transmit following an underrun and set Status register bit 23. (General only). 




22 




X 


X 


1 = Enable abort interrupt and reset Status register bits 23 and 18. (General only). 
= Disable abort interrupt and reset Status register bits 23 and 1 8. (General only). 




21 


X 


X 


X 


1 = Enable data set change interrupts and reset Status register bits 29 and 20. 
= Disable data set change interrupts and reset Status register bits 29 and 20. 




20 


X 


X 


X 


1 = Enable timer interrupts and reset Status register bits 25, 24 and 1 9. 
= Disable timer interrupts and reset Status register bits 25, 24 and 19. 




19 


X 


X 


X 


1 = Enable Transmit buffer empty interrupts. 
= Disable Transmit buffer empty interrupts. 




18 


X 


X 


X 


1 = Enable Receive buffer full interrupts and reset Status register bits 21 and 1 1 . 

= Disable Receive buffer full interrupts and reset Status register bits 21 and 1 1 . 

1 = Enable Receive buffer full. Received Check Character buffer full and received abort interrupts. Reset Status register bits 21, 14, 11 and 9 
= Disable interrupts listed above. Reset Status register bits 21, 14, 11 and 9. 




17 


X 


X 


X 


or 1 = Output complement via RTS and disable automatic RTS control logic. 




16 


X 


X 


X 


1 = Enable transmitter logic. 

= Disable transmitter logic after transmitting available data. 




15 


X 


X 


X 


1 = Test mode. = Normal operation. 




14 


X 


X 


X 


1 = Load data at CRU bits 0-11 into Control register. 




13 


X 


X 


X 


1 = Load data at CRU bits - 7 into Timer register. 

= Move Timer register contents to timer and start timer. 




12 


X 


X 


X 


1 = Update the Receive CRC with the next output to CRU bits 0-9. Read Receive CRC at CRU bits 0-15. 





TMS9903 
CONTROL 
REGISTER 



TMS9903 
REGISTER 
SELECT 



TMS9903 

DEVICE 

RESET 



Let us begin by examining the Control register; bit interpretations are defined in Table 
3-12. 

When you write to a TMS9903, CRU bits 31 through 12 will always access the Control register. 

Control register bits may be divided into the following groups: 

• Device reset 

• Register select 

• Variations within mode specifications — which are made in the Parameter register 

• Interrupt enable/disable 

• Direct device control 

In most cases, when you set or reset a TMS9903 Control register bit, this bit setting — and 
its associated logic — remains in effect until you specifically change the bit setting. When 
setting a bit to select a data register, be sure to reset any select bits that were previously 
set. If two or more register select bits are set simultaneously, you will receive no error 
message, but the device will probably malfunction. 

Let us now examine Control register bits by group. 
There are three device reset CPU bits: 31, 30, and 29. 

When you write a or a 1 to CRU bit 31, the entire device is reset; all interrupts are disabled 

and all flags and register select bits are reset to (with the exception of Control register bit 14 
and Status register bit 22, which are set to 1). This causes the first data to be loaded into the 
Parameter register, while a transmit buffer empty condition is reported in the Status register. 

After resetting the TI\MS9903 by writing a 1 or to CRU bit 31 and loading the 
Parameter register (CRU bits to 11), you must next clear the transmitter and 
receiver by writing a 1 and then a to CRU bit 30. (It does not matter whether you clear 
transmitter or receiver logic first, so long as you do clear each set of logic before attempting 
to use it.) You must also initialize CRC accumulation logic at the transmitter and the 
receiver by writing 1 and then to CRU bit 29. 

In summary, the following steps are required to reset and initialize a TMS9903: 

1) Write 1 or to CRU bit 31. This resets the entire device and enables loading of the Parameter register. 

2) Load the Parameter register (CRU bits 0-11). establishing the operating mode and configuration. 

3) Write 1 1 to CRU bits 30 and 29. This initializes the transmitter and transmitter CRC logic. 

4) Write 00 to CRU bits 30 and 29. This resets the receiver and receive CRC logic. 

(Note that when you write to CRU bits 31, 30, and 29, you will always access Control register bits 30, 31, and 29; only 
CRU bits 0-11 have multiple destinations within the TMS9903.) 

After resetting the TMS9903 and initializing transmit/receive logic, you will next select addressable locations to read 
from or write to. 

Selecting the data location from which you will read is straightforward. Normally, CRU bits 0-8 
will contain the Receive buffer contents, while CRU bits 9-31 are taken from the Status register. 
But you can also read one of three 1 6-bit CRC characters. We may illustrate TMS9903 register ad- 
dressing during a CPU read as follows: 



TMS9903 
INITIALIZE 
TRANSMIT/ 
RECEIVE 



INITIALIZE 
CRC 



TMS9903 
READ 
REGISTER 
ADDRESSING 




From Status register 

Computed CRC for received 

message (Control register 

bit 12= 1) 

Received CRC for received 

SDLC frame (Control register 

bit 26= 1) 

Computed CRC for transmitted 

message (Control register 

bit 24 or 25= 1) 

Otherwise: 

From Receive buffer 

From Status register 
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Note carefully that in SDLC mode you can read two receive cyclical redundancy check characters: the first is 
computed under program control by receive logic for the received frame: the second is received at the end of 
the frame. 

The final 16 bits of the information field are the received cyclical redundancy character. To read the received cyclical 
redundancy character, set Control register bit 26 to 1. To read the cyclical redundancy character connputed by receive 
logic for the received frame, set Control register bit 12 to 1. These two cyclical redundancy characters will be identical 
if a valid message was received. 

In Synchronous and Asynchronous modes there is no defined end-of-message. Rather, a control character in the 
received data stream is interpreted as an end-of-message indicator, in which case two previously received data charac- 
ters are interpreted as the received cyclical redundancy character. Your program logic must compare the two data 
characters which are being interpreted as the received CRC character with the computed check character, read from 
receive logic after setting Control register bit 12 to 1. 

When the CPU reads from the TMS9903, if Control register bits 1 2, 24, 25, and 26 are all reset to 0, then as the default 
case CRU bits 0-8 are taken from the Receive buffer; higher numbered CRU bits are taken from the Status register, as 
always. 

When writing to the TMS9903, Control register address bits used to select a data location 
for the low numbered CRU bits may be illustrated as follows: 



TMS9903 
WRITE 
REGISTER 
ADDRESSING 



31 30 29 28 


27 


26 25 24 23 22 21 20 19 18 17 


16 15 14 


13 12 11 10 9 


876543210 


MM 


X 


x|x|x| 1 1 1 1 1 1 


1 h 


x|x| 1 1 


1 1 1 II 1 II 


I 1 1 



Control Register 




Control Register Bits 



Sync2 register 
(up to 1 bits) 

Synci register 
{up to 10 bits) 



Transmit buffer (9 bits) 
(also default location) 

Transmit CRC register 
(up to 1 bits) 

Parameter register 
1 2 bits) 

Timer register 
(8 bits) 

Receive CRC register 
(up to 1 bits) 



High numbered CRU bits always go to the Control register. Low numbered bits go to the write location whose 
register select bit within the Control register is 1 . 

Following a reset. Control register bit 1 4 is set to 1 , therefore data written to CRU bits 0-1 1 loads the Parameter register. 
When you write into the high-order Parameter register bit (bit 11), Control register bit 14 is automatically reset. 

But this is an exception. When you set any other register select bit in the Control register it remains set until you 
specifically reset it. 

If the Parameter register select bit (Control register bit 14) is set and you want to write to another addressable location, 
then you must reset Control register bit 14 to when setting another select bit to 1. 

If all select bits in the Control register are 0, then as a default case data will be written to the Transmit buffer. 
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TMS9903 

INTERRUPT 

ENABLE/DISABLE 



TMS9903 

TRANSMIT 

CONTROLS 



You can only write into the Sync2 register in Synchronous or SDLC modes. 

You can only write into the Synci register in Synchronous mode — and only in those variations of Synchronous mode 
that use the Synci register. Variations of Synchronous mode are described later. 

There are two Control register bits, 28 and 23, which you use to specify variations of mode specifications. We 
will describe these two bits together with Parameter register bit settings, since Control register bits 23 and 28 
are logically extensions of the Parameter register. 

Five conditions capable of requesting interrupts have separate enable bits: these are Con- 
trol register bits 22 through 18. When you write a 1 to any of these Control register bits, the 
associated interrupt logic is enabled; when you write a to that Control register bit, interrupt 
logic is disabled. In most cases, when you write a or a 1 to an enable/disable bit, you reset 
any associated Status register bits. Exceptions are the Transmit buffer empty status and the Received CRC register full. 

We will discuss individual interrupts in more detail later when looking at TMS9903 interrupt logic in general. 

Direct device control bits consist of transmitter control and receiver controls. 

Looking first at the transmitter, you must enable transmit logic, after clearing it, by setting 
Control register bit 1 6 to 1 ; transmit logic remains enabled until you reset this bit to 0. Transmit 
logic will not disable itself in the middle of transmitting a character; if you write a to Control 
register bit 1 6 part way through a character's transmission, the character will be transmitted and 
transmit logic will then be disabled. 

If you never write to Control register bit 1 7 following a reset, then the RTS output signal level is automatically 
controlled by tr ansmitter logic. As soon as you enable transmitter logic by writing a 1 to Control register bit 16, RTS is 
output low; RTS remains low until you disable transmitter logic by writing a to Contro l reg ister bit 1 6. But if you ever 
write to Control register bit 1 7. you immediately disable the automatic control of the RTS output level. Now the RTS 
output level becomes the reciprocal of Control register bit 1 7. 

There are two ways in which you can include transmitted characters in any cyclical redundancy character com- 
putation. 

If you select the Transmit buffer by setting Control register bit 25 to 1, then the character which you write to the 
Transmit buffer is also included in the transmit cyclical redundancy character computation. 

If you select the Transmit buffer as the default write location (i.e., no address bits in the Control register are set to 1), 
then the character which you write to the Transmit buffer will not be included in the transmit cyclical redundancy 
character computation unless you set Control register bit 24 to 1 and then output the character to Transmit CRC logic. 
That is, using bit 24 of the Control register you can write to either the Transmit buffer or to Transmit CRC logic, but not 
to both at the same time. 

When a large sequence of contiguous characters is to be included in the transmit cyclical redundancy character 
computation, use Control register bit 25. 

When characters are to be selectively included and excluded in the transmit cyclical redundancy character com- 
putation, use Control register bit 24. 

There is no receiver enable control equivalent to the transmitter enable (Control register bit 1 6). As 

soon as you clear receive logic, it is enabled and will begin to sample data arriving via RxD. As 

each character is assembled, it is transferred to the Receive buffer. If a received character is to be 

included in the computed receive cyclical redundancy character, program logic must output that character to Receive 

CRC logic after reading it from the Receive buffer. When you set Control register bit 1 2, data output to CRU bits 0-9 will 

go to Receive CRC logic. 

Note that CRC logic is not necessarily connected to the transmitter or receiver. The cyclical redundancy calculation 
registers may be used independently of transmit or receive logic. 

The Test mode bit (Control register bit 1 5) is normally left reset to 0. When you set this bit 
to 1 the following connections occur: 

1) TxD is connected to RxD. 

2) RTS is connected to CTS, and DSR is held low. 

3) TxC and RxC are both connected to the timer logic clock, which operates at 32 times its normal rate. 

This is similar to TMS9902 Test mode, with the exception that, in the TMS9903, the timer determines Receive and 
Transmit data rates in Test mode. 



TMS9903 
RECEIVE CRC 



TMS9903 
TEST MODE 
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We will next describe the Parameter register. You will normally write into this register once 
during any operation in order to define operating modes and options within these modes. 

After resetting the TMS9903 by writing to CRU bit 31, you simply output the parameter code to 
CRU bits 0-1 1. Resetting the device automatically selects the Parameter register as the write loca- 
tion for the data at CRU bits 0-1 1 . You could also select the Parameter register by writing Os to CRU bits 27, 26, 25, 24, 
13, and 12, and writing a 1 to CRU bit 14. Parameter register contents are interpreted as follows: 



TMS9903 

PARAMETER 

REGISTER 



11 10 



CRU Bit 
Parameter register 



0-5 bits/character 
1-6 bits/character 
10-7 bits/character 
11-8 bits/character 
10 0-9 bits/character 

- Divide ^J by 3 to generate timer clock 

1 - Divide ^ by 4 to generate timer clock 



Non-SDLC 
- No parity 

1 - No parity 

1 - Even parity 
1 1 - Odd parity 



SDLC 
Point-to-point 
Loop master 
Loop slave - inactive 
Loop slave - active 



- Synchronous - general 
1 - SDLC 
1 - Monosync 

1 1 - Bisync 

1 - Unassigned 

1 1 - Asynchronous with two stop bits 
1 1 - Asynchronous with one stop bit 
1 1 1 - Unassigned 

OO-CRC-16 (X16 + x15 + x2 + 1) 

1 - CRCC-1 2 (Xl 2 + x"" ■• + X3 + X2 + X + 1 ) 

1 -Revised CRCC-1 6 (X^S + xl* + X + 1) 
1 1 -CRC-CCIT (Xie +x12 + x5 + 1) 

- Transmit/receive at input clock rate 

1 - Transmit/receive at input clock rate ^ 32, and 

use zero-complementing NRZI encoding. 

Parameter register bits 6, 7, and 8 determine the operating mode for transmit and receive logic, and some op- 
tions within the selected mode. 

When you select Asynchronous mode, you also select either one or two stop bits. 



In Asynchronous mode, when you set Control register bit 23 to 1, then as soon as an un- TMS9903 
derrun occurs transmit logic will output a continuous low level (break) on TxD. But note ASYNCHRONOUS 

carefully that setting Control register bit 23 to 1 does nothing until an underrun occurs. Once BREAK LOGIC 
an underrun does occur, you cannot load new data into the Transmit buffer until you reset 
Control register bit 23 to to end the break. 

If Control register bit 23 is reset to 0, then following an underrun a continuous high signal is output via TxD. You can at 
any time restart transmission by loading data into the Transmit buffer — in which case the high level output at TxD 
ends and the next character is transmitted according to the Asynchronous protocol options specified in the Parameter 
register. 

There are three Synchronous mode options and one SDLC mode option. These four options share Sync character 
logic, as shown in Table 3-13. This table applies to transmit and receive logic. 

Let us first consider SDLC transmit logic. 
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Table 3-13. TMS9903 Synchronous and SDLC Mode Sync 
Character and Underrun Options 



Parameter 
Register 
CRU Bit 


IVIODE 


SYNC 
Character 


Underrun Fill Character 1 


Control Register 
CRU Bit 23 = 


Control Register 
CRU Bit 23 = 1 


8 


7 


6 











Synchronous- 
General 


None 


Abort 


[SYNC2] 








1 


SDLC 


7Ei6 


Abort 


[SYNC2] 





1 





Synchronous- 
Monosync 


[SYNC1] 


[SYNC2] 


[SYNC2] 





1 


1 


Synchronous- 
Blsync 


[SYNC1] - [SYNC2] 


[SYNCH -[SYNC1] 


[SYNC2]-[SYNC1] 



[ ] Means: "contents of register named within brackets" 



TMS9903 
SDLC 

TRANSMIT 
OPERATION 



Every frame must begin with a flag character, therefore 7Ei 6 is always output as the leading Sync 
character. You will subsequently reset Control register bit 23 toO, since underruns are not allowed 
within an SDLC frame. Should an underrun occur, the transmitter will abort, outputting a con- 
tinuous high signal and setting appropriate status bits. In order to transmit a valid end-of- 
message, you must read the computed transmit check character (selected via Control register bit 
24 or 25), set Control register bit 23 to 1 , load a flag (7E-\q) character into the Sync2 register, and output the computed 
transmit check character as two data bytes. Now allow an underrun to occur; the contents will be output when the un- 
derrun occurs. Since Sync2 contains a flag character, you will have terminated the frame by transmitting the message 
check character and closing flag, as required by SDLC protocol. 

There is another way of ending a frame's transmission. 

instead of allowing an underrun and outputting the frame's closing flag from the Sync2 register, you can suppress 
SDLC Q insertion by writing a 1 to Control register bit 28, then outputting the closing flag (or flags) as a simple se- 
quence of 8-bit data characters. 

If you are operating the TMS9903 using HDLC protocol, then you must output 7Fig as your 

abort character. To obtain a valid HDLC abort following a transmit underrun you should write 

the HDLC abort character to the Sync2 register, then leave Control register bit 23 set to 1 while 

the frame is being transmitted. Now if an underrun occurs, an HDLC abort character will be output from the Sync2 

register. 

When detecting a new frame, SDLC receive logic synchronizes itself on flag character 7Eig, 
which is also the specified Sync character. Consequently the setting of Control register bit 23 
and the underrun fill character options shown in Table 3-13 do not apply. When receive logic 
detects another flag character, it assumes it has received the frame's closing flag. SDLC receive 
logic can also detect an abort. SDLC receive logic sets appropriate status flags and generates an 
interrupt request, if enabled. 

The three Synchronous modes shown in Table 3-13, together with their underrun fill character options, allow 
you (under program control) to emulate any of the synchronous protocol options commonly encountered. 



TMS9903 
HDLC ABORT 



TMS9903 
SDLC 
RECEIVE 
LOGIC 



TMS9903 
EXTERNAL 
SYNC LOGIC 



External synchronization uses no leading Sync characters at the head of a message. You can 

emulate this protocol by choosing the general synchronous option. 

For TMS 9903 transmit logic, make sure that CTS is low before you enable the transmitter; then as 
soon as RTS goes low, messa ge transmission begins. A station that receives this transmitted 
message can use the low RTS output as its external Sync input 

TMS9903 receive logic will use the DSR Modem input as it s external synchronization signal. The station which 
transmits the signal to the TMS9903 must generate a low DSR in put ju st before it starts transmitting a message. The 
program controlling TMS9903 r eceiv e logic must detect the low DSR input by interrogating the appropriate Status 
register bit, and upon detecting DSR active should start receiving. 
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In Monosync mode a single Sync character occurs at the head of a new message. In Bisync mode two Sync 
characters occur at the head of a new message. Both of these options are allowed. 

The Monosync mode outputs the contents of the Synci register at the head of a transmitted 
message and synchronizes on a received nnessage by matching received characters against the 
contents of the Synci register. 



TMS9903 

MONOSYNC 

LOGIC 



BISYNC 
LOGIC 



In Bisync mode Synci contents are output twice at the head of a transmitted message. 

Receive logic assumes that a new message has been detected when two contiguous characters 
match the contents of the Synci register. 

By loading appropriate data into the Synci and Sync2 registers you can transmit and detect 
ASCII, EBCDIC, or any other Sync characters. 

When an underrun occurs in Monosync mode, a single Sync character is output. By loading the appropriate character 
into the Sync2 register you can transmit and detect any underrun fill character. 

In the Bisync option greater underrun flexibility is needed. In some cases, following any underrun two Sync characters 
are transmitted; but in standard Bisync protocol DLE-SYN character combinations are output following an underrun. 
When Control register bit 23 equals the TMS9903 will output two Sync characters from the Synci register. To meet 
the requirements of Bisync protocol you load the DLE character into the Sync2 register, load the SYN character into the 
Synci register, and leave Control register bit 23 set to 1 . Other bisync logic (in particular, the generation and detection 
of special control character combinations) must be handled by a supervisory program. 

Control register bit 28 adds some flexibility to the options shown in Table 3-13. However, this control bit applies 
only to SDLC and Bisync modes. In SDLC mode, when Control register bit 28 is reset to 0, TMS9903 transmitter logic 
will insert a after every five consecutive Is transmitted. Setting Control bit 28 to 1 inhibits this zero bit insertion in 
SDLC mode. 



TMS9903 
SYNC STRIP 



In Bisync mode, when Control register bit 28 is set to 1 any received character that matches 
the contents of the Synci register is discarded. This allows you to strip received underrun 
Sync characters. 

Parameter register bits 5 and 4 serve different functions in Synchronous and SDLC modes. 

In Synchronous and Asynchronous modes Parameter register bits 5 and 4 are used to 
specify odd parity, even parity, or no parity. When parity is specified, parity bits will automat- 
ically be generated for data characters that are transmitted and will be tested for data characters 
received. But parity does not apply to the contents of the Synci or Sync2 registers. You must 
add your own parity bit to the contents of these registers if you want to transmit Sync characters with parity. The Sync 
registers are each ten bits wide so that you can add one parity bit to the longest specifiable character (nine bits). 
Receive logic will automatically check the parity of received Sync characters, since received logic treats all receive 
characters as data. 
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In SDLC mode. Parameter register bits 5 and 4 specify Loop or Non-loop mode; in fact, they 
specify the way in which an EOP character (7Fig) is handled. 

In a point-to-point configuration the EOP character has no significance, and is ignored. 

As a loop master, transmit logic pays no attention to the EOP character; however, receive logic treats the EOP character 
as a frame's closing flag. This is necessary, since the polling EOP character which a loop master transmits around the 
loop will eventually be received as the closing flag for the last frame transmitted by a loop secondary. 

The loop slave inactive mode is selected for an SDLC loop secondary that is not transmitting data, but may be 
receiving data. The loop slave active mode, in contrast, is selected for a secondary station in the SDLC loop that 
wishes to transmit to the primary station. 

In loop slave inactive mode, a TMS9903 will initially retransmit received data without delay. But, upon detecting an 
EOP character in the received stream, theTMS9903 will introduce one bit delay before retransmitting received data. So 
long as you never electrically disconnect a secondary station in an SDLC loop, the inactive slave mode will take care of 
timing and protocol requirements of a secondary loop station coming on-line. But if you wish to electrically disconnect 
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a TMS9903 secondary station in an SDLC loop, you will require external logic which detours upstream data around the 
electrically disconnected secondary, while breaking the detour and including the secondary when it is electrically con- 
nected. Here is the appropriate logic: 



Up-loop data 
RxD 



^ 



IN LOOP 



<> 



TxD' 



o 



o 



^c^ 



Down-loop data 
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TMS9903 CLOCK 
RATE OPTION 



NRZI SELECT 



You will normally leave a TMS9903 operating in loop slave active mode if it is functioning as a secondary station in an 
SDLC loop. You will only switch to loop slave inactive mode when the secondary station has just entered the 
loop and is not yet synchronized (has not received EOP). In the loop slave active mode, TI\/IS9903 receive logic will 
seek the next EOP character. Upon receiving an EOP character it will convert this character to a flag, which becomes 
the opening flag for the frame which the station wishes to transmit to the primary. So long as a TI\/IS9903 is left 
operating in loop slave active mode, it will continue to trap receive EOP characters and transnnit frames behind 
them. When a TMS9903 has no further frames to transmit, you should leave it in loop slave active mode, but turn off 
the transmitter by resetting Control register bit 16 to 0. 

For a discussion of SDLC loop secondary station logic see Chapter CI in Volume 3. 

Parameter register bits 0, 1, and 2 allow you to specify 5, 6, 7, 8, or 9 data bits per received 
character. Note that if parity is enabled, the parity bit is not counted in this specification. 

If Sync and control characters are eight bits wide, then you cannot specify less than 8-bit 

characters in Synchronous mode. This is because receive logic does not automatically switch 

from the specified bits per character to eight bits per character when receiving Sync or control 

characters. Moreover, a program controlling receive logic cannot make this switch, since it does not know it has 

received a Sync or special control character until the character is in the Receive buffer — by which time it is too late to 

make a change. 

Parameter register bit 1 1 allows you to transmit and receive data at the transmit and 
receive clock rates, or at these clock rates divided by 32. This is normally a standard Syn- 
chronous mode option. With the TMS9903 it is available in all modes: Synchronous, SDLC, 
and Asynchronous. This bit should be reset to during operation as an SDLC loop slave. 

During synchronous or SDLC operation, if data is being sampled on every 32nd clock 

pulse (Parameter register bit 1 1 is 1) then NRZI encoding and decoding of serial data is assumed; that is, the data 

signal changes state to transmit a or remains in the same state to represent a 1. 

Parameter register bits 9 and 10 are used to specify the cyclical redundancy character 
algorithm which will be used by transmit and receive logic. 

CRC-16 is the normal algorithm used by synchronous and asynchronous protocols. 

CRCC-12 is the algorithm used in synchronous and asynchronous protocols with 6-bit characters. 

Revised CRCC-16 is the protocol frequently used in standard Bisync protocol. 

CRC-CCIT is the standard SDLC algorithm. 

Parameter register bit 3 is used by interval timer logic. This bit will be discussed later when we describe the interval 
timer. 

We will now examine TMS9903 Status register bit settings, which are summarized in Table 
3-14. Status register bits may be divided into the following groups: 

• Interrupt status 

• Input signal levels 

• Transmit logic status 

• Receive logic status 

• Timer logic status 
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Table 3-14. TMS9903 Synchronous Communications Controller CRU Bit Assignments 
when Reading from the TMS9903 



!=£ 
CD m 

§1 


MODE 






U 

Z 


o 


u 


>- 
5 


z 
> 


-1 

Q 


Function 


Reset Condition 


U 2 


< 


(0 


(0 






31 


X 


X 


X 


1 = Any interrupt pending 


No interrupt pending 


30 


X 


X 


X 


1 = One or more Register Load Control flags set. 


No Control flag set 


29 


X 


X 


X 


1 = DSR or CTS or automatic RTS signal level change occurred 


Output to CRU bit 21 


28 


X 


X 


X 


Complement of CTS Input 




27 


X 


X 


X 


Complement of DSR input 




26 


X 


X 


X 


RTS level under automatic control. Transmitter active state If RTS is under program control 




25 


X 


X 


X 


1 = Timer decremented to 


Output to CRU bit 20 


24 


X 


X 


X 


1 = Timer error. Bit 25 was already 1 when timer decremented to 


Output to CRU bit 20 


23 




X 


X 


1 = Abort followed an underrun (General only) 


Output to CRU bit 22 


22 


X 


X 


X 


1 = Transmit buffer empty 


Output to CRU bit 25 


21 


X 


X 


X 


1 = Receiver buffer full 


Output to CRU bit 1 8 


20 


X 


X 


X 


1 = Interrupt request accompanying RTS, DSR, or CTS signal level change (Bit 29=1) 


Bit 29 = or Output to bit 21 


19 


X 


X 


X 


1 = Interrupt request accompanying timer time out (Bit 25 = 1 ) 


Bit 25 = or Output to bit 20 


18 




X 


X 


1 = Interrupt request accorfipanying an abort (Bit 23 = IXGeneral only) 


Bit 23 = or Output to bit 22 


17 


X 


X 


X 


1 = Interrupt request accompanying a Transmit buffer empty 


Output to CRU bit 25 


16 


X 






1 = Interrupt request accompanying Receiver buffer full (Bit 21=1) only 


\ 






X 




1 = Interrupt request accompanying Receiver buffer full (Bit 21=1) 


/ No active interrupting 








X 


1 = Interrupt request accompanying Receiver buffer full (Bit 21 = 1) or abort received 
(Bit 1 4 = 1 ) or Closing flag received and received check character ready to be read 
(Bit 13 = 1) 


/ condition 


15 


X 


X 


X 


RxD input level 




14 


X 






1 = Start bit detected 


Stop bit(s) received 








X 


1 = Abort received 


Output to CRU bit 1 8 


13 


X 






1 = First character data bit received 


Stop bit(s) received 








X 


1 = Closing flag has been received and check character may be read 


Output to bit 26 


12 


X 






1 = Receive framing error detected 


Error free character received 








X 


1 = Overrun error detected - receive data overrunning previous frame's check character 


Output to bit 26 


11 


X 


X 


X 


1 = Receive overrun error detected 


Output to bit 1 8 


10 


X 


X 




1 = Receive parity error detected 


Valid character received 








X 


1 = Zero insert error detected 


Output to bit 26 


9 


X 


X 




1 = Any receive error in most recently received character 


Valid character received 








X 


1 = Flag detected 


Output to bit 1 8 



The interrupt status bits include CRU bit 31, which reports any active interrupt request, and CRU bits 20 through 

16, which identify individual interrupts. These status bits are self-evident. In non-vectored interrupt configurations you 
will test CRU bit 31 to find out if this particular TMS9903 has any active interrupt requests. In a vectored interrupt con- 
figuration you can ignore CRU bit 31 , since the interrupt acknowledge process will identify the TMS9903 as the device 
with the active interrupt request. In each case, the interrupt service routine must exannine CRU bits 20 through 16 in 
order to determine which interrupt requests are active. The interrupt service routine must resolve its own interrupt 
priorities. 

Input Modem signals DSR and CTS modify Status register bits 27 a nd 28 , resp ectively. The c omp lement of the 
input signal level is reported. Status bit 29 is set to 1 when either DSR, CTS, or automatic RTS signal level 
changes. This signal le vel c hange can cause an interrupt request, in which case Status register bit 2 is s et. In 

many serial I/O devices, CTS going high in the middle of a transmit operation forces a transmit abort, while DSR going 
high in the middle of a receive operation disables receive logic. The TMS9903 does not make such critical decisions; 
the supervisory program must respond appropriately. 

When RTS output level is being controll ed a utomatically, the complement of RTS is reported in Status register 

bit 26. But as soon as you start controlling RTS level by writing to Control register bit 17, Status register bit 26 reports 
the active state of the transmitter. 

The serial data input signal RxD has its level reported in Status register bit 1 5. 

There are two status bits associated with transmitter logic: bit 22 reports Transmit buffer empty and bit 23 re- 
ports a transmitter abort (in those modes that can generate an abort). If interrupt logic for these conditions has been 
enabled, then Status register bits 18 and/or 17 will also be set. 

There are a number of Status register bit settings associated with receive logic, but there is only one interrupt status 
bit associated with receive logic — bit 16. Therefore you must use the various receive status bits in order to identify 
active error or non-error conditions within receive logic. 

In all modes Status register bit 21 is set when the Receive buffer is full — and should be read within one character 
time. 

In Synchronous mode. Status register bit 1 1 reports a receive overrun error, while Status register bit 10 reports 
a receive parity error. Either of these errors causes Status register bit 9 to be set. 

In Asynchronous mode, a receive framing error, overrun error, or parity error is reported in status bits 12, 11, 
and 10, respectively. Status bit 9 reports one or more of these error conditions. In Asynchronous mode, two status 
bits are also set at the beginning of each received character. Status bit 14 is set when a valid start bit has been 
detected for the character, while status bit 13 is set when the first valid data bit has been detected. 

In SDLC mode, a receive overrun is reported in status bit 1 1 and a receive zero insert error is reported in status 

bit 10. The receive zero insert error means that five contiguous 1 bits were received, followed by a flag character, with- 
out the expected zero inserted between them. Thus, status bit 10 will be set when the sequence 01 1 1 1 1101 1 1 1 12 is 
received. While a frame is being received, Status register bit 14 is set when an abort is detected and Status 
register bit 9 is set when any flag character is detected. 

An unusual and interesting error reported in SDLC mode is the receive CRC overrun error. If a new frame's data 
is received before you read the previous frame's cyclical redundancy check character, then status bit 1 2 is set. 

There are two timer logic status bits; bit 25 is set to 1 whenever the timer decrements to zero. If timer interrupts 
have been enabled, then status bit 19 is also set. You must acknowledge a time-out before another time-out occurs. 
You acknowledge a time-out by outputting to Control register bit 20. If you do not do so, then on the next time-out 
Status register bit 24 is set. 

You can examine Status register bit 30 at any time to see if one or more write location select bits are set in the 
Control register. 
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TMS9903 INTERRUPT LOGIC 

There are seven conditions that can generate interrupt requests within the TIVIS9903. Three of the seven condi- 
tions combine to generate a single interrupt request status. Therefore, there are five interrupt request statuses for the 
seven interrupt generating conditions. This may be illustrated as follows: 

Control 

Status Register Status 

Register Interrupt Register 

Condition Enable Interrupt 

Bit No. Bit No. Bit No. Interrupt 

29 21 20 — DSR, CTS, or automatic RTS level change 

25 20 1 9 — Tinner time out 

22 1 9 1 7 — Transmit buffer empty 

23 22 1 8 — Transmit abort 

Receive buffer full 21 ,,,^^^ 

End of SDLC frame 1 3 J^> 1 8 1 6 — Receive interrupt 

Receive abort 1 4 ' 

The TMS9903 has no internal interrupt priority arbitratio n log ic. When one or more conditions capable of request- 
ing an interrupt occur, if the interrupt has been enabled, then INT is output low and Status register bit 31 is set to 1 . An 
interrupt service routine responding to the TMS9903 interrupt request must now interrogate Status register bits in 
order to determine which interrupt requests are active. Program logic is responsible for all interrupt priority arbitra- 
tion. These are the interrupt priorities which normally apply in serial I/O devices: 

1) HIGHEST PRIORITY. Receive buffer full (Status register bits 16 and 21 set) 

2) Transmit buffer empty (Status register bits 17 and 22 set) 

3) Modem signal level change (Status register bits 20 and 29 set) 

4) Receive abort detected (Status register bits 16 and 14 set) 

5) Transmitter abort (Status register bits 18 and 23 set) 

6) End of SDLC frame detected (Status register bits 16 and 13 set) 

7) LOWEST PRIORITY. Timer interrupt (Status register bits 19 and 25 set) 

TMS9903 INITIALIZATION PROGRAM LOGIC 

The first step in any TMS9903 operation is usually to initialize the device. Here are the necessary steps: 

1) Reset the device by writing or 1 to Control register bit 31. 

2) Now output appropriate Parameter register settings. 

3) Output data to Control register bits 18 through 22 to enable appropriate interrupts. 

4) In Synchronous and SDLC modes, load appropriate codes into the Sync2 and/or Synci registers. These two 
registers are not used in Asynchronous mode. 

5) To initialize receive logic, write to Control register bit 30. If cyclical redundancy is being used, initialize receive 
CRC logic by writing to Control register bit 29. As soon as this step is complete, receive logic becomes active and 
starts to assemble received data. 

6) To initialize transmit logic, write 1 to Control register bit 30. If cyclical redundancy is being used, initialize transmit 
CRC logic by writing 1 to Control register bit 29. Transmit logic is now initialized, but it is not yet enabled. 

7) Transmit logic will not become active until you enable the transmitter by writing 1 to Control register bit 16. When 
you enable the transmitter, you should also load data into the Transmit buffer. Refer to our earlier discussion of 
Control register bits 25 and 24, where data output to the Transmit buffer is described, with or without associated 
CRC accumulation. 

TMS9903 ASYNCHRONOUS OPERATIONS 

When you select Asynchronous mode, data will be transmitted with a parity bit if selected, 
plus one or two stop bits, as specified by the Parameter register. Whenever the Transmit buffer 
beconies empty, an interrupt request will be generated if the Transmit buffer empty interrupt 
has been enabled, and appropriate status bits will be set — as described earlier. You have one 
character time within which to respond by outputting another character, or else an underrun will occur. Following an 
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underrun, a continuous high (marl<ing) signal or a continuous low (break) signal will be output, depending on the set- 
ting of Control register bit 23. See the break discussion given earlier for details. 



TIVIS9903 

ASYNCHRONOUS 

RECEIVE 



When beginning a receive operation, sample the start bit detected status (Status register bit 
14) to identify the beginning of a new received message. This status cannot generate an inter- 
rupt request. To process received characters, use Receive buffer full interrupt request logic. As 
characters are received, program logic must read characters out of the Receive buffer within 
one character time, and check for any of the asynchronous receive error conditions by reading error Status register bits 
at the same time. Received data and status can be read together by reading CRU bits through 1 5 from the TMS9903. 

There are no other special programming considerations associated with asynchronous operation of the TMS9903. Con- 
versely, any other protocol requirements must be met by the supervisory program's logic. 

TMS9903 SYNCHRONOUS OPERATIONS 

Most of the logic associated with Monosync and Bisync protocols must be provided by the supervisory program 
that controls TMS9903 transmit and receive operations. The only logic capabilities provided by the TMS9903 itself 
are the various Sync register programmable options, the error and normal operation statuses reported, and the 
character length definition. 

For a discussion of the Sync character options, refer to our earlier description of the Parameter register. 

For a description of the statuses reported, see the Status register discussion and interrupt logic summary. 

TMS9903 SDLC OPERATIONS 

When discussing the Parameter register we explained how you will use the Sync2 register in order to transmit 
and receive frames; but there are additional SDLC protocol requirements and some common protocol variations 
which need to be discussed. 

SDLC and HDLC protocols are described in Chapter CI of Volume 3. In SDLC protocol, the first byte of every frame is 
the address field, while the second byte is a control field. In HDLC protocol the address field can have any length, while 
the control field can be either one or two bytes long. Some variations of SDLC protocol insert a logical control field after 
the control field; the logical control field can have any length. Address field, control field, and logical control field 
characters are all eight bits wide. Information field characters can have any data bit width. The number of bytes 
in a multibyte address or logical control field is determined by examining a specific character bit. For example, a pro- 
tocol may specify that the last byte of an address field will have a 1 in the low-order bit, while all prior bytes have a in 
the low-order bit. 

The TMS9903 has no on-chip logic designed to handle address, control, or logical control fields. Device program- 
ming can specify the number of bits per character — and this specification may change from character to character — 
and that is all. Moreover, the supervisory program must take into account primary or secondary station logic. 

A supervisory program at a primary station must transmit secondary station addresses and must interpret received ad- 
dresses as identifying a frame's source. 

At a secondary station, the supervisory program must always transmit its own address at the head of a frame and must 
examine the address at the head of a received frame to see if the rest of the frame should be read or ignored. 

When the last byte of the control field (or logical control field) has been received, program logic must change the bits- 
per-character specification in the Parameter register before processing the first character of the information field — 
should the information field use a different character length. Remember, the bits-per-character specification in the 
Parameter register applies only to receiver logic; you specify transmit character size by the number of bits you output 
to the Transmit buffer. Thus it is a simple matter to change character size from character to character as protocol may 
require. It is also possible for a received character to have a different number of bits than a simultaneously transmitted 
character. 

TMS9903 receive logic in SDLC mode does have one very useful end-of-frame capability: the received check 
character (which must be the 1 6 data bits preceding the frame's closing flag) is automatically loaded into a received 

CRC register. The microprocessor can read this received check character and compare it with a computed check 
character. 

But there are some additional uses for this received CRC logic. 

A valid SDLC frame must have at least 32 bits between the beginning and closing flags; these bits include an 8-bit con- 
trol field, and a 16-bit cyclical redundancy check character. Frequently, 32-bit frames are transmitted and received to 
pass a command or response with no associated data. An error occurring within such a short frame can cause complex 
logic problems; it may be difficult to identify beginning and ending flags for subsequent frames, since the ending flag 
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for the short frame may go undetected. But you can use the TMS9903 receive CRC logic to identify short received 

frames. If you do not get a valid status indicator telling you that the received check character is available, then you 
know you have received a short frame. 

SDLC protocols allow frames to be separated by a single flag character, which serves as the closing flag for one 
frame and the opening flag for the next frame. Alternatively, a number of flag characters may separate two 
frames. Either case can be handled by the TMS9903. 

When describing the Parameter register, we explained how you can generate a frame's closing flag out of the Sync2 
register, after allowing an underrun, or inhibit zero insertion and transmit flag characters as data. Since you can in- 
dividually specify characters that will or will not be included in cyclical redundancy check accumulations, processing 
non-data characters as though they are data characters presents no difficulties to a TI\/1S9903. You can use either 
method of ending a frame to separate frames with one or more flag characters. 

If you have generated an end-of-frame using underrun logic, then loading the next frame's first address field byte while 
a single flag character is being transmitted will cause a single flag to separate the two frames. If you let the underrun 
last longer, then flag characters will continue to be output until you begin the next frame by writing the frame's first ad- 
dress field byte as data to the Transmit buffer. If you are transmitting flags as data without zero insertion, then the num- 
ber of flags separating frames is strictly a function of program control — but you must make certain that an underrun 
does not occur. 
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Let us now examine programming requirements within an SDLC loop. 

There are no special programming requirements for the primary station in an SDLC loop. If you 
generate an abort at the end of a transmitted frame's closing flag, then the flag's trailing bit, 
together with the first seven 1 bits of the abort, constitute an EOP character — which is transmitted around the loop in 
order to poll secondaries. When this EOP character returns to the primary station's receive logic, it is treated as a clos- 
ing flag. (Refer to our discussion of the TMS9903 Parameter register for details.) 

Secondary stations within the SDLC loop should be run in the SDLC loop slave inactive mode until the secondary sta- 
tion has become synchronized with the loop — that is, has received the EOP character and begun retransmitting with a 
one-bit delay. At this time, change the secondary station mode to SDLC loop slave active. In the active condition, the 
secondary station will seek the next EOP character arriving at RxD. If the transmitter has been enabled, the TMS9903 
will convert this received EOP character to the opening flag character for the frame which it wishes to transmit. The 
program controlling the secondary SDLC can end the transmission with a closing flag and then an abort, or with an 
EOP character. The closing flag and following abort generate an EOP character for the next downstream secondary — 
and multiple flags between frames. A closing EOP character will be converted by the next downstream secondary to a 
flag or will be passed on to the primary, which interprets EOP characters at receive logic as closing flags. A closing EOP 
character, therefore, generates a single flag separating two transmitted frames. 

For a discussion of normal status and error status that may occur during transmit and receive operations, refer to 
our earlier description of the Status register. Also, refer to our earlier description of the Parameter register for logic 
which you will use to abort a mistransmitted frame, or to detect an abort in a received frame. But remember, it is en- 
tirely up to the supervisory program to interpret status bits and to handle aborts as required by the local system logic. 

TMS9903 INTERVAL TIMER LOGIC 

The TMS9903 has an interval timer. You initialize the interval timer by loading a timer count into the Timer 
register. Remember, you set Control register bit 13 to 1 in order to select the Timer register as the destination for data 
output via CRU bits through 7. As soon as you reset Control register bit 13 to you enable the timer, which starts to 
decrement. The rate at which the timer decrements depends on Parameter register bit 3 and Control register bit 15. 

Parameter register bit 3 allows you to divide the 4> clock by either 3 (Parameter register bit 3 = 0) or 4 (Parameter 
register brt^S - 1 ) in order to create a timer clock. The timer decrements once every 64 timer clock pulses. For ex- 
ample, if $ is a 3 MHz clock and Parameter register bit 3 is 0, then the timer clock will be 3 MHz divided by 3, or 1 MHz. 
Therefore, the timer will decrement once every 64 microseconds. 

The contents of the Timer register itself are never altered. Rather, the Timer register contents are shifted into timer 
logic, where they are decremented. When a time-out occurs. Status register bit 25 is set; if timer interrupts have 
been enabled. Status register bit 19 is also set when the interrupt request occurs. As soon as the timer decre- 
ments to it reloads Timer register contents and starts decrementing again. Thus the value you load into the Timer 
register defines the interval between time-outs, which will apply until you load another value into the Timer register. 

You must acknowledge a time-out by writing a 1 to Control register bit 20. If this does not occur before another 
time-out, then a timer error will be reported and Status register bit 24 will be set. 

Timer logic is most frequently used with serial I/O in order to create default interrupts that alert a supervisory program 
to hangup or any error condition which is not identifying itself. 
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When you select the Test mode by writing 1 to Control register bit 1 5, the timer operates at 32 times its normal 
speed. This allows you to speed up timer testing. In addition, the timer acts as both transmit clock and receive 
clock in Test mode; therefore you can specify automatic baud rates for testing the transmitter and receiver. 
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DATA SHEETS 

The following pages contain specific electrical and timing data for the following devices: 

. TMS9900 CPU 

. TMS9940 Microcomputer 

• TIM9940 Clock Generator/Driver 

• TMS9901 Programmable Systems Interface 

• TMS9902 Asynchronous Communications Controller 

• TMS9903 Synchronous Communications Controller 
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TMS 9900 ELECTRICAL AND MECHANICAL SPECIFICATIONS 

ABSOLUTE MAXIMUM RATINGS OVER OPERATING FREE-AIR TEMPERATURE RANGE (UNLESS OTHERWISE NOTED) 

Supply voltage, Vcc (see Note 1 ) -0.3 to 20 V 

Supply voltage, V/qd (see Note 1 ) -0.3 to 20 V 

Supply voltage, Vss (see Note 1 ) -0.3 to 20 V 

All input voltages (see NotR 1) -0.3 to 20 V 

Output voltage (with respect to Vss) -2 V to 7 V 

Continuous power dissipation 1.2 W 

Operating free-air temperature range 0°C to 70°C 

Storage temperature range — 55°C to IBO'C 

'Stresses beyond those listed under "Absolute Maximum Ratings" may cause pernnanent damage to the device. This is a stress rating only and 
functional operation of the device at these or any other conditions beyond those indicated in the "Recommended Operating Conditions" 
section of this specification is not implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability. 

NOTE 1: Under absolute maximum ratings voltage values are with respect to the most negative supply, Vgg (substrate), unless otherwise 
noted. Throughout the remainder of this section, voltage values are with respect to Vss- 

RECOMMENDED OPERATING CONDITIONS 





MIN 


NOM 


MAX 


UNIT 


Supply voltage, VgB 


-5.25 


-5 


-4.75 


V 


Supply voltage, Vcc 


4.75 


5 


5.25 


V 


Supply voltage, Vqd 


11.4 


12 


12.6 


V 


Supply voltage, Vs5 





V 


High-level input voltage, V|h (all inputs except clocks) 


2.2 


2.4 


Vcc+1 


V 


High-level clock input voltage, V|h(0) 


VdD-2 




Vdd 


V 


Low-level input voltage, V||_ (all inputs except clocks) 


-1 


0.4 


0.8 


V 


Low-level clock input voltage, V|l{^) 


-0.3 


0.3 


0.6 


V 


Operating free-air temperature, Ta 







70 


°c 



ELECTRICAL CHARACTERISTICS OVER FULL RANGE OF RECOMMENDED OPERATING CONDITIONS 
(UNLESS OTHERWISE NOTED) 



PARAMETER 


TEST CONDITIONS 


MIN TYPf MAX 


UNIT 


l| Input current 


Data bus during DBIN 


V| = Vss to Vcc 


±50 ±100 


mA 


WE, MEMEN, DBIN, Address 
bus. Data bus during HOLDA 


V, = Vss to Vcc 


±50 ±100 


Clock 


V| = -0.3 to 12.6 V 


±25 ±75 


Any other inputs 


V, = Vss to Vcc. 


±1 ±10 


VqH High-level output voltage 


Iq = -0.4 mA 


2.4 Vcc 


V 


Vol Low-level output voltage 


l0 = 3.2 mA 


0.65 


V 


Iq = 2 mA 


0.50 


iBB(av) Supply current from Vbb 




0.1 1 


mA* 


'CC(av) Supply current from Vcc 




50 75 


mA* 


iDD(av) Supply current from Vqd 




25 45 


mA* 


Input capacitance (any inputs except 
' clock and data bus) 


Vbb = -5, f=1MHz, 
unmeasured pins at Vss 


10 15 


pF 


Cj(0i) Clock-1 input capacitance 


Vbb = -5, f=1MHz, 
unmeasured pins at Vss 


100 150 


PF 


Ci(02) Clock-2 input capacitance 


Vbb = -5, f=1MHz, 
unmeasured pins at Vss 


150 200 


pF 


Cj(<^3) Clock-3 input capacitance 


Vbb = -5. f=1MHz, 
unmeasured pins at Vss 


100 150 


pF 


Cj(04) Clock-4 input capacitance 


Vbb = -5, *=1MHz, 
unmeasured pins at Vss 


100 150 


pF 


CqB Data bus capacitance 


Vbb = -5, f=1MHz, 
unmeasured pins at Vss 


15 25 


pF 



t AM typical values are at T^ = 25°C and nominal voltages. 
*D.C. Component of Operating Clock 



Data sheets on pages 3 -D2 through 3 -D 1 7 are reprinted by permission of Texas Instruments Incorporated. 
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TIMING REQUIREMENTS OVER FULL RANGE OF RECOMMENDED OPERATING CONDITIONS 



PARAMETER 


MIN 


MOM 


MAX 


UNIT 


tc(«) 


Clock cycle time 


300 


333 


500 


ns 


M-k) 


Clock rise time 


5 


12 




ns 


*f(*) 


Clock fall time 


10 


12 




ns 


^M4>) 


Clock pulse width, high level 


40 


45 


100 


ns 


ts{</.) 


Clock spacing, time between any two adjacent clock pulses 





5 




ns 


«d(«) 


Time between rising edge valid any two adjacent clock pulses 


73 


83 




ns 


tsu 


Data or control setup time before clock 1 


30 


ns 


th 


Data hold time after clock 1 


10 


ns 



SWITCHING CHARACTERISTICS OVER FULL RANGE OF RECOMMENDED OPERATING CONDITIONS 



PARAMETER 


TEST 
CONDTTIONS 


MIN 


TYP 


MAX 


UNIT 


tPLH(B)ortpHL(B) 


All other outputs 


Cu = 200pF 




20 


40 


ns 


tPLH(C)0'"tpHL{C) 


Propagation delay CRUCLK, WE, MEMEN, WAIT, DBIN 


30 


ns 






I I 



I I 



\ 



■tc(0)- 



y V 



7 V 



ts(0)- 



I I 



tr(0)- 



I I I r 



■tf{0) 



J V 



CLOCK TIMING 
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-> > — 



\NfU lb 



., I \_ 



•A 



/ V 



i V 



I tou, (C) 



-\| 'PHL 



ALL OTHER OUTPUTS 



i V 



/ 



I I 



tpo, (C) 



tp, h(C)- 



/ V 



/ 



/ 



\ 
r 



-tpLH(C)ORtpHL(C) 



/ V 



7 \ 



-'phi <C) 



\ 



I 



-tpLnlCjOR tpHL(C) 



1 



-tpLH(B)ORtpHL(B) 



VALID 



SIGNAL TIMING 



TMS9940 

TMS 9940E EPROM PROGRAMMING 



ERASURE 



Before programming, the TMS 9940E is erased by exposing the chip through the transparent lid to 
high-intensity ultraviolet light (wavelength :253.7 nanometers). The recommended exposure is 1 watt • sec- 
onds per square centimeter. This can be obtained by, for instance, 20 to 30 minutes exposure of a filterless 
Model S52 shortwave UV lamp atxjut 2.5 centimeters above the EPROM. After exposure all bits are in the 
"0" state. 



PROGRAMMING 



The TMS 9940E should be initialized by RESET before the programming sequence begins. The EPROM 
consists of 16K bits of program memory organized as 2K bytes (8 bits each) located at (starting) address 
000016- Data is transferred into the CPU for programming through P24(MSB)— P31 (LSB). Taking the PE 
signal active high (to V|p) initializes the internal address pointer of OOOO1 6 and inputs the first byte of data 
(see Figure 8). After a minimum delay of 40 clock cycles, PROG can be applied (V|p, 50 ms) and the data 
present on P24^P31 updated to the next byte. The falling edge of PROG inputs the new byte of data to the 
next location and after a minimum delay of 25 clock cycles the PROG pulse can be applied again. This 
sequence is continued until the entire 2K bytes have b»een programmed. Note that the memory is pro- 
grammed in sequence starting at OOOO1 6; and the input data must be valid at the rising edge of PE or falling 
edge of PROG. 
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RECOMMENDED PROGRAMMING/TEST FUNCTION CONDITIONS 



PARAMETER 


MIN NOM MAX 


UNIT 


tr TST.PE, PROG input rise time 


100 


ns 


tf TST.PE, PROG input fall time 


100 


ns 


tsu Input data setup time to rising edge of PE, TST or to falling edge of PROG 





ns 


th Input data hold time past rising edge of PE, TST 


80tc(<t) 


ns 


th(P-da) Input data hold time past falling edge of PROG 


50tc(<<,) 


ns 


th(P-PE,T) PE. TST input hold time past falling edge of PROG 





ns 


tsu(P-PE,T) PROG input setup time to rising edge of PE, TST 





ns 


th(T-PL) PROG Input pulse low past rising edge of TST, PE 


80tc(.<,) 


ns 


W(PL) PROG Input pulse width low 


50tc(,i,) 


ns 


W(PHP) PROG input pulse width high in the programming mode 


50 


ms 


W(PHT) PROG input pulse width high in the test mode 


"•cW 


ns 



NOTE: Tvnirtg diagrams in Figure 8. 



V|P 
RST/PE V|H - 
V|L 

V|H 
DATA 

V|L 

VlP 



V|H 
DATA 



INT2/PROG 



-X 



•-lsu(P-PE,T)-» 



X 



'\-m 



\- 



FIGURE 8 - EPROM PROGRAMMING TIMING DIAGRAM 
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FIGURE 9 - TEST FUNCTION TIMING DIAGRAM 
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TEST FUNCTION 



This test function allows loading a program into the RAM area of the TMS 9940 through pins P24 through 
P31 . This program can then be executed, and the results of this execution used to verify operation of the 
TMS 9940. The program could include error messages as well as a successful completion message sent to 
a peripheral device accessed through the CRU. 



The processor should be initialized by RESET before any test sequence begins. Data is directly loaded in 
sequence into the RAM through P24 (MSB)— P31 (LSB). Taking the TST signal high (to V|p) initializes the 
internal address pointer to 8300 1 6 (starting address of RAM) and inputs the first byte of data (see Figure 9). 
After a minimum delay of 40 clock cycles PROG can be applied (V|h, 4 clock cycles minimum) and the data 
present on P24 — P31 updated to the next byte. The falling edge of PROG inputs the new byte of data to the 
next location and, after a minimum delay of 25 clock cycles, PROG can be applied again. This sequence is 
continued until the desired data has been loaded into the RAM. Taking TST inactive will then jump the 
processor to the address specified by the last 16 bits loaded. Note that the RAM is loaded in sequence 
starting at 8300i 6, and the input data must be valid at the rising edge of TST or on the falling edge of PROG. 



TMS 9940 ELECTRICAL SPECIFICATIONS 

ABSOLUTE MAXIMUM RATINGS OVER OPERATING FREE-AIR TEMPERATURE RANGE (UNLESS 
OTHERWISE NOTED)* 

Supply Voltage, Vccit -0.3 to 20 V 

Supply Voltage, VcC2 -0.3 to 20 V 

Programming Voltage, PE -0.3 to 35 V 

All InputVoltages -0.3to20 V 

Output Voltage -2to7 V 

Continuous Power Dissipation 1 .5 W 

Operating Free-Air Temperature Range 0°C to 70°C 

Storage Temperature Range -55°C to 150°C 

* stresses beyond those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of 
the device at these or any other conditions beyond tt)Ose indicated in the "Recommended Operating Conditions " section of this specification is not implied. Exposure to 
absolute-maximum-rated conditions for extended periods may affect device reliability. 

tAII voltage values are with respect to Vss- 

RECOMMENDED OPERATING CONDITIONS 



PARAMETER 


MIN MOM MAX 


UNIT 


Supply voltage, Vqci 


5 


V 


Supply voltage, Vcc2 


5 


V 


Supply voltage, Vss 





V 


High-level Input voltage, V|h 


2 


V 


Low-level input voltage, V||, 


0.8 


V 


Program/test Input voltage, V|p 


26 


V 


Operating free-air temperature, Ta 


70 


°c 



ELECTRICAL CHARACTERISTICS 



PARAMETER 


TESTCONDmONS 


MIN TYP MAX 


UNrrs 


l| 


Input current, any inputs 


V| = VsstoVcc 


±10 


mA 


VOH. 


High-level output voltage, any outputs 


Iq = 0.4 mA 


2.4 


V 


Vol. 


Low-level output voltage, any outputs 


Iq = 2 mA 


0.4 


V 


icci. 


Supply current from Vqci 




10 


mA 


ICC2' 


Supply current from Vcc2 




150 


mA 


Cj. 


Input capacitance, any inputs 


f = 1 MHz, unmeasured pins at Vss 


15 


PF 


Co, 


Output capacitance, any outputs 


f = 1 MHz, unmeasured pins at Vss 


15 


PF 
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CLOCK CHARACTERISTICS 



The TMS 9940 has an internal oscillator and a two-phase clock generator controlled by an external or 
crystal. The user may also disable the oscillator and directly inject a frequency source into the XTAL2 input. 
The crystal frequency and the external frequency source must be double the desired system CLOCK 
frequency. 



Internal Oscillator 



The internal oscillator is enabled by connecting a crystal across XTAL1 and XTAL2. The system CLOCK 
frequency 1 /tc((/)). is one-half the crystal oscillator frequency, fosc- 



PARAMETER 


PART NUMBER 


TEST CONDITIONS 


MIN 


NOM 


MAX 


UNITS 


fosc 


TMS9940E,TMS9940M 


TA = 0°Cto70°C 


0.5 


5 


6.12 


MHz 


fosc 


TMS 9940E-40, TMS 9940M-40 


0.5 


4 


4.10 


MHz 


fosc 


TMS 9940E-30, TMS 9940M-30 


0.5 


3 


3.07 


MHz 


fosc 


TMS 9940E-20, TMS 9940M-20 


0.5 


2 


2.05 


MHz 


fosc 


TMS 9490E-10, TMS 9940M-10 


0.5 


1 


1.02 


MHz 



Note: tcv^ 1/'osc 
*c(rf>) ^ 2 ■ tcy 

TIM9904 

ELECTRICAL SPECIFICATIONS 

Absolute Maximum Ratings Over Operating Free-Air Temperature Range (Unless Otherwise 
Noted) 

Supply voltage: \/qq (see Note 1) 7 V 

Vqd (see Note 1) 13 V 

Inputvoltage: OSCIN 5.5V 

FFD -0.5 V to 7 V 

Operating free-air temperature range 0°C to 70°C 

Storage temperature range -65°C to 1 50°C 

NOTE 1 : Voltage values are with respect to the network ground terminals connected together. 

Recommended Operating Conditions 





MIN 


NOM 


MAX 


UNIT 


Supply voltages 


vcc 


4.75 


5 


5.25 


V 


VOD 


11.4 


12 


12.6 


V 


HIgMevel output current, (qh 


<t>\,02.03.04 


-100 


UA 


All others 


-400 


mA 


Low-level output current, Iql 


01 , 02, 03, 04 


4 


mA 


All others 


8 


mA 


Internal oscillator frequency, f^^ 




48 


54 


MHz 


External oscillator pulse width, tw(osc) 


25 


ns 


Setup time, F F D input (with respect to f all ing edge of 03) , t^y 


50 


ns 


Hold time, FFD input (with respect to falling edge of <t>3) , t^ 


-30 


ns 


Operating free-air temperature, T/y 







70 


'c 
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Electrical Characteristics Over Recommended Operating Free-Air Temperature Range 
(Unless Otherwise Noted) 



PARAMETER 


TEST CONDITIONS 


MIN 


TYPt 


MAX 


UNIT 


V|H 


High level input voltage 




2 


V 


V|L 


Low-level 
input voltage 


FFD 




0.5 


V 


OSCIN 


0.8 


Vt>-Vt- 


Hysteresis 


FFD 




0.4 


0.8 




V 


V|K 


Input clamp voltage 


Vcc=4.75V, Vqo = 11 4 V, l| = -18mA 


-1.5 


V 


VOH 


High-level 
output voltage 


01, 02, 03, 04 


Vcc = 4.75 V, 

VqD = 11.4 V to 12.6 V 


lOH = -100 >iA 


Vdd-2 


VdD-15 


Vdd 


V 


Other outputs 


IQH = -400 *iA 


2.7 


3.4 




Vol 


Low-level 
output voltage 


01,02,03,04 


Vcc= 4.75 V, VoD = 11-4V 


Iql - 4 mA 




0.25 


0.4 


mA 


Other outputs 


IqL " 4 mA 




0.25 


0.4 


Iql =8 mA 




0.35 


0.5 


Input current at 
l| 

maximum input voltage 


FFD 


Vcc = 5.25 V, Vdo = 12-6V 


V| = 7 V 


0.1 


mA 


OSCIN 


V| = 5.5 V 


0.3 


l|H 


High-level 
input current 


FFD 


Vcc = 5 25V, Vqd = 12.6 V, V| = 2.7 V 


20 


mA 


OSCIN 


60 


l|L 


Low-level 
input current 


FFD 


Vcc = 5.25 V, Vdd= 12.6 V, V| = 0.4 V 


-0.4 


mA 


OSCIN 


-3.2 


lOS 


Short-circuit 
output currentt 


All except 
01,02,03,04 


Vcc = 5.25 V 


-20 




-100 


mA 


icc 


Suppiv current from Vqc 


Vcc = 5 25V, FFD and OSCIN at GND, 
Outputs open 




105 


175 


mA 


'DO 


Supply current from Vqo 


Vcc = 5.25 V, Vdd= 12.6 V, 

FFD and OSCIN at GND, Outputs open 




12 


20 


mA 



'aii tvpical values are at Mqq = 5 V, Vqd = 12 V, T^ 
tNot more than one output should be shorted at a ti 
and 04 do not have short-circuit protection. 



= 25 C. 

me. and duration of the short-circuit should not exceed one second. Outputs 01 , 02. 03, 



oscnjnjnjTrLiajijnjiJijnj~uiJiJijnjnj^^ 
oscouT _j-i rn r— 1 i i i i i i i i n 



?i_ 

«2" 

54" 
FFD~ 
FFQ" 



TYPICAL PHASE RELATIONSHIPS OF INPUTS AND OUTPUTS (INTERNAL OSC) 
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Switching Characteristics, T/^ = 25°C, Vqq^ = 5 V, Vcq2 =" 12 V, fogg= 48 MHz 



PARAMETER 


TEST CONDITIONS 


MIN 


TYP 


MAX 1 


UNIT 


'out 


Output frequency, any or TTL 


Output loads: 
01,03,04: 100 pF toGND 
02: 200 pF toGNO 
Others; R|_= 2 kS2, 
Cl-15pF 


3 


MHz 


'out 


Output frequency, OSCOUT 


12 


MMz 


'c(0) 


Cycle time, any output 


330 


333 


340 


ns 


'r(0) 


Rise time, any <t> output 


5 




20 


n$ 


•f<0) 


Fall time, any output 


10 


14 


20 


n» 


'w(0) 


Pulse width, any output high 


40 


55 


70 


ns 


«01L,02H 


Delay time, 1 low to 02 high 





5 


15 


tw 


'02L,03H 


Delay time, 02 low to 03 high 





5 


15 


ns 


«03L. 04H 


Delay time, 03 low to 04 high 





5 


15 


ns 


'04L, 01H 


Delay time, 04 low to 0I high 





5 


15 


ns 


<01H,02H 


Delay time, 01 high to 02 high 


73 


83 


96 


ns 


«02H,03H 


Delay time, 02 high to 03 high 


73 


83 


96 


ns 


t03H,04H 


Delay time, 03 high to 04 high 


73 


83 


96 


ns 


«04H, 01H 


Delay time, 04 high to 0I high 


73 


83 


96 


ns 


'0H,0TL 


Delay time, <t>n high to 0n TTL low 


-14 


-4 


6 


ns 


«0L, 0TH 


Delay time, 0n low to 0n TTL. high 


-29 


-19 


-9 


ns 


'03L, OH 


Delay time, 03 low to FFQ output high 


-18 


-8 


2 


ns 


*03L, QL 


Delay time, 03 low to FFQ output low 


-19 


-9 


1 


ns 


'0L, OSOH 


Delay time, low to OSCOUT high 


-30 


-20 


-10 


ns 


«0H, OSOL 


Delay time, FFQ high to OSCOUT low 


-27 


-17 


-7 


ns 



0.7 V Jft-'fl) ■»tX.0.7V I 



p— 'o4H,01H 



-.^l* -d* tf^ H- '«2H . (J3H . 
! -f 9.4 V\ 



)2 '01L.g2H i« Q, ^ 



'«)2L, C.3H , 

I I I0.7 V 



'«i3H, C>4H 




i I V3L, 4H. 

I I 



\_f 



02 



^U 



MJ 



4 

OSCOUT 



J\..J\.J\ 



FFD 
INPUT 



f 



^94v\ 



h— — H— '04L,U1H 



/ 9.4 V+- 
J \ 



7V J . X0 7\ 



\J 



MJ 



OTv/ 4.0,7\ 



UI 



<«H,OS0L-M I*- 
'OL, OSOL- 



A. 1.3 V 



/ 



V 



n^ 



JMJ' 



I 



FFQ 
OUTPUT 



/ 



| « >l 'C)3L,QL 



\ 



SWITCHING CHARACTERISTICS, VOLTAGE WAVEFORMS 
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EQUIVALENT OF D INPUT 



Vcc 




EQUIVALENT OF OSCIN INPUT 



Vcc- 



2.3 kn NOM 




EQUIVALENT OF XTAL 1 AND 
XTAL 2 INPUTS 




EQUIVALENT OF 
TANK INPUTS 



Vcc- 



'ii J; 



/77 



TYPICAL OF 

01, 4>2, 03 AND 04 OUTPUTS 



vdd 



TYPICAL OF OSCOUT. Q, AND 
ALL * TTL OUTPUTS 

-Vcc 





SCHEMATICS OF INPUTS AND OUTPUTS 

TMS9901 

TMS9901 ELECTRICAL SPECIRCATIONS 

Absolute Maximum Ratings Over Operating Free Air Temperature Range (Unless Otiierwise Noted) * 

Supply voltage, Vcc -0.3 Vto 10 V 

All Inputs and output voltages -0.3 Vto 10 V 

Continuous power dissipation 0.85 W 

Operating free-air temperature range 0°C to /OX 

Storage temperature range -65°Cto 150°C 

'Stresses beyond those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of 
the de>rice at these or ariy other coTKlitians beyond those Indicated in the "Recommended Operatifig CorKMions" section of this specification is not impli^^ 
absolute maximum rated conditions tor extended periods may affect device reliability. 

Recommended Operating Conditions* 



PARAMETER 


MIN NOM MAX 


UNIT 


Supply voltage. Vcc 


4.75 5.0 5.25 


V 


Supply voltage, Vss 





V 


High-level Input voltage, V|h 


2.0 Vcc 


V 


Low-level Input voltage, V||. 


Vss-. 3 0.8 


V 


Operating free-air temperature, Ta 


70 


•c 
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Electrical Characteristics Over Full Range of Recommendecl Operating Conditions 
(Unless Otherwise Noted) * 



PARAMETER 


TEST CONDITIONS 


MiN TYP MAX 


UNrr 


VOH 


High level output voltage 


IOH = -100^ 


2.4 


vcc 


V 


IOH=-200^ 


2.2 


vcc 


V 


Vol 




l0L = 3.2 mA 


vss 


0.4 


V 


ii 


Input current (any Input) 


V| = OVtoVcc 


±100 


mA 


'CC(av) 


Average supply current from Vqc 


'c(*)= 330 ns, Ta = 70°C 


150 


mA 


C| 


Small signal input capacitance, any Input 


f = 1 MHz 


15 


PF 



Timing Requirements Over Full Range of Operating Conditions 



PARAMETER 


MIN TYP MAX 


UNtr 


«c(*) 


Clock cyde time 


300 333 2000 


ns 


M*) 


Clock rise time 


5 


40 


ns 


<f(*) 


Ck>ck fall time 


10 


40 


ns 


«w(<ftH) 


Ckxk pulse wkfth (high level) 


225 


ns 


«w(*L) 


Ckick pulse vndth (low level) 


45 


300 


ns 


MCC) 


CRUCLK pulse vndth 


100 185 


ns 


tsu1 


Setup time for CE, S0-S4, or CRUOUT before CRUCLK 


100 


ns 


tsu2 


Setup time for interrupt before $ kw 


60 


ns 


tsu3 


Setup time for inputs before valkl CRUIN 


200 


ns 


th 


Now time for CE. S0-S4, or CRUOUT after CRUCLK 


60 


ns 



*NOTE: All voltage values are referenced to Vss. 



Switching Characteristics Over Full Range of Recommended Operating Conditions 



PARAMETER 


TESTCONDrnON 


MIN TYP MAX 


UNrr 


tpdi Propagatkjn delay. CE to valkl CRUIN 


CL=100pF 


300 


ns 


tpd2 Propagatkxi delay. 80-84 to valkl CRUIN 


CL=100pF 


320 


ns 


tpdS Propagatfon delay. $ km to valkl IKITREA.ICO-ICa 


CL = 100pF 


110 


ns 


tpd Propagatron delay, CRUCLK to valkl data out (P0-P1 5) 


CL=100pF 


300 


ns 
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«w(«L) 



-*\ \*- tr(0) _JU-^[<-'f(0) }-« tc(0) H 

II III ' 

li IT-IP U 



I ' 



INTERRUPT 



\ 



!*• "4- «su1 

I 



1 



— ^ h-'su2 



/ 



-H h- tpd3 



y — I. 



H tpdl 



tpd3 J k- 



/ 



rA 



«w(CC) 



I I 

'sui h — k- •h -H 



|-« tpd2 



lOOOOOOOJt VALID ADDRESS 


mm 


JOOOIJ VALID ADDRESS [ )[ 


S0-S4 1 1 

1 1 
' 1 


1 

1 


1 
[.^ 'su3 -^ 


mmmmmmmmmmfm ;v»uo...o.„ x 


INT1-INT15, PO-PI5I 1 1 1 
1 1 1 
> 1 1 1 


mmmmmimmmmmmmm ™-c„„. x 


CRUIN 1 1 
' 1 1 


1 




MM v.,„.„ mmmmmmmmmmmmm 



CRUOUT 

NOTE 1: ALL TIMING MEASUREMENTS ARE FROM 10% and 90% POINTS 

SWITCHING CHARACTERISTICS 
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TMS 9902 ELECTRICAL SPECIFICATIONS 

Absolute Maximum Ratings Over Operating Free Air Temperature Range (Unless Otiierwise Noted) * 

Supply voltage, Vcc -0.3 Vto 10 V 

All inputs and output voltages -0.3 V to 10 V 

Continuous power dissipation 0.55 W 

Operating free-air temperature range 0°G to 70°C 

Storage temperature range -65°Cto 150°C 

'Stresses beyond those listed under "Absolute Maximum Ratings" may cause permanent damage to ttie device. This is a stress rating only and functional operation of 
the device at these or any other conditions beyond those indicated in the "Recommended Operating Conditions" section of this specification Is not implied. Exposure to 
at>solute maximum rated conditions for extended periods may affect device reliability. 

Recommended Operating Conditions * 



PARAMETER 




MAX 


UNrr 


Supply voltage, Vcc 


4.75 5.0 


5.25 


v 


Supply voltage, Vss 





v 


High-level input voltage, V|h 


2.0 


Vcc 


V 


Low-level input voltage, V|l 


VSS-.3 


0.8 


V 


Operating free-air temperature, Ta 





70 


-c 



Electrical Characteristics Over Full Range of Recommended Operating Conditions 
(Unless Otherwise Noted) * 



PARAMETER 


TEST CONDITIONS 


MIN TYP MAX 


UNrr 


Vqh High level output voltage 


IOH = -100mA 


2.4 


Vcc 


V 


IOH=-200mA 


2.2 


Vcc 


V 


Vol Low level output voltage 


lot = 3.2 mA 


Vss 


0.4 


V 


l| Input current (any Input) 


V| = OVtoVcc 


±10 


mA 


'CC(av) Average supply cun-ent from Vcc 


'c(<^) = 330 ns. Ta = 70°C 


100 


mA 


C i Small signal input capacitance, any input 


f = 1 MHz 


15 


PF 



Timing Requirements Over Full Range of Operating Conditions 



PARAMETER 


MIN TYP MAX 


UNrr 


tc(<^) Clock cycle time 


300 333 667 


ns 


tr(,^) Clock rise time 


5 40 


ns 


tf(^) Ckxk fall time 


10 40 


ns 


'w(0H) Clock pulse width (high level) 


225 


ns 


tw(<^g Clock pulse width (low level) 


45 


ns 


•w(CC) CRUCLK pulse width 


100 185 


ns 


*su1 Setup time for CE tjefore CRUCLK 


150 


ns 


tsu2 Setup time for S0-S4, or CRUOUT before CRUCLK 


180 


ns 


*h Hold time for CE, S0-S4, or CRUOUT after CRUCLK 


60 


ns 



'NOTE: All voltage values are referenced to Vss. 

Switching Characteristics Over Full Range of Recommended Operating Conditions 



PARAMETER 


TCST 
CONOmON 


MIN TYP MAX 


UNrr 


tpdl Propagation delay, CFto valid CRUIN 


CL = lOOpF 


300 


ns 


tpd2 Propagation delay, S0-S4 to valid CRU IN 


CL = 100pF 


320 


ns 
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<^TL 



|— tr(«s) 



\ 



n^^ A 



'sul 1* 



L >j th |« >4 : tpdl 

Y CRUBIT ADDRESS n Y CBU BIT ADDRESS n+1 Y * CRU BIT ADDRESS m V 



S0-S4 UNKNOWN A CRU BIT ADDRESS n T CBU BIT ADDRESS n+1 



-t 



n 



CRUOUT UNKNOWN I CRU DATA OUT 



-if- 



Y CRU DATA OUT n Y CRU DATA OUT n+1 ¥ Y UNKNOWN Y 



[-- <pd2 -*^ 



DON'T CARE 



DONT CARE 



"W VALID \/ 
-*• INPUT ■¥• 

A BITm A 



SWITCHING CHARACTERISTICS 
NOTE: ALL SWITCHING TIMES ARE ASSUMED TO BE AT 10% OR 90% VALUES. 



EQUIVALENT OF I/O INPUTS 

VCC Vcc 



INPUT 

o f- 



n 



c 



1 



EQUIVALENT OF I/O OUTPUTS 



J[ 



OUTPUT 

o 



j!^ 



INPUT AND OUTPUT EQUIVALENTS 
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EQUIVALENT OF OUTPUTS 



EQUIVALENT OF INPUTS 



J 



J 



I 

1 



OUTPUT 
O 



INPUT j 

o , \r^ 



J^ 



TMS 9903 ELECTRICAL SPECIRCATIONS 

ABSOLUTE MAXIMUM RATING OVER OPERATING FREE AIR TEMPERATURE RANGE 
(UNLESS OTHERWISE NOTED)* 

Supply voltage, Vqc (Note) -0.3 Vto 10 V 

All inputs and output voltages -0.3Vto20V 

Continuous power dissipation 0.7 W 

Operating free-air temperature range 0°C to 70°C 

Storage temperature range -65°Cto 150°C 

*S tr » M e t beyond those fislad under "Absolute Maximum Ratings" may cause permanent damage to ttte device. This is a stress rating only and functional operation of 
the davioe at these or any other condHicris beyond tlwse indicated in the "Ftocommended Operating C^XKJitians" section of the specification is no^ 
■bsokile maximum rated conditions for extended periods may affect device reliability. 

RECOMMENDED OPERATING CONDITIONS 



PARAMETER 


MIN NOM MAX 


UNIT 


Supply voltage, Vcc 


4.75 5.0 5.25 


V 


Supply voltage, Vss 





V 


High-level input voltage. V|h 


2.0 2.4 Vcc 


V 


Low-level input voltage, V||. 


Vss -3 OA 0.8 


V 


Operating free-air temperature. Ta 


70 


°c 



ELECTRICAL CHARACTERISTICS OVER FULL RANGE OF RECOMMENDED OPERATING 
CONDITIONS (UNLESS OTHERWISE NOTED) 



PARAMETER 


TESTCONOmONS 


MIN 


TYP 


MAX 


UNIT 


VOH 


High-level output voltage 


IOH=-100M 
Ioh=-200mA 


2.4 
2.2 




Vcc 


V 


Vol 


Low-level output voltage 


IOL = 3.2 mA 


Vss 




0.4 


V 


ll 


Input current (any input) 


V| = OVtoVcc 


±10 


mA 


■CC(av) 


Average supply current from Vcc 


tc(4,) = 330ns,tA = 70°C 


150 


mA 


Cj 


Capacitance, any input 


f= 1MHz, all other pins at OV 


15 


PF 



NOTE: All voltages are in reference to Vsg. 
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SCR 
OR 
SCT 



RIN 



U-tw(«H)*i 



tc(DC) 



RECEIVE DATA 



SAMPLE PULSE 



TRANSMIT DATA 



SHIFT PULSE 



XOUT 




DATA 



A r 



»DONTCARE^[ 



/\ 



/\ 



VALID DATA 



X 



VALID 
DATA 



PARAMETER 


Mm 


TYP 


MAX 


UNIT 


tc(DC) Receiver/transmit data clock cycle time 




4 




flS 


tw(^) Clock pulse width (high level) 




2 




flS 


iM(4A.) Ck)ck pulse width (kwv level) 




2 




MS 


tr Risetime 




12 




ns 


tf Fall time 




12 




ns 


tsu Setup time for RIN before SCR (DRCK32 = 0)* 




i^ 




ns 


th Hold time for RIN after SCR (DRCK32 = 0)* 




50 




ns 


td Delay time, SCT to valM XOUT 




400 




ns 



*Kk) setup, hoM, or data synchronization is required for pin in the divide-by-32 nxxle (DRCK32 = 1 ). 

RECEIVE/TRANSMIT DATA CLOCK TIMING DIAGRAM 
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TIMING REQUIREMENTS OVER FULL RANGE OF RECOMMENDED OPERATING CONDITIONS 



PARAMETER 


MIN TYP MAX 


UNIT 


tc(,^) Clock cycle time 


300 333 


ns 


tf^^) Clock rise time 


5 


ns 


tf(0) Ckxd( fall time 


10 


ns 


Wh) Clockpulaewidih (high level) 


225 


ns 


tw(i^) Clock pulse width (low level) 


45 


ns 


tw(CC) CRUCU( pulse wkfth 


iM 1&S 


ns 


tsui Setup time lor Ce before CRUCLK 


190 


ns 


tsu2 Setup time for S0-S4 or CRUOUT before CRUCLK 


^20 


ns 


th HoM time for S0-S4,CE. or CRUOUT after CRUCLK 


60 


ns 



SWITCHING CHARACTERISTICS OVER FULL RANGE OF RECOMMENDED OPERATING 
CONDITIONS 



PARAMETER 


TEST 
CONDITION 


MIN TYP MAX 


UNIT 


tpD1 Propagatnn delay. CE to valid CRUIN 


Cl - 100 pF 


300 


ns 


tp02 Propagatkjn delay, S0-S4 to valM CRUIN 


Cl - 100 pF 


i26 


ns 



/ 



I I 

r((Jl tf<0, ^ J. 



K-J" 



\ 






h— •4— «h 



S0-S4 UNKNOWN 



x 



CRUBIT 
ADDRESS r 



10% I I 



X 



CRUBIT 
ADDRESS n+1 



.}^ T\ 



*~2 — h — H 

90%! 



th 



CRUOUT UNKNOWN 



X 



CRU DATA 
OUT 



X 



CRU DATA 
OUTn 




CRUBIT 
ADDRESS 



I <PD1 

I 



3CD( 



XI 



SEXXXXXXESSEXXXXXSX^S^CSX 



TIMING DIAGRAM 
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Chapter 4 

SINGLE CHIP NOVA MINICOMPUTER 

CENTRAL PROCESSING UNITS 

In this chapter we are going to lool( at two microprocessors which are the world's first single chip reproductions 
of established 1 6-bit minicomputers. We are going to describe two products which reproduce, on a single chip, 
the logic of a Nova Central Processina Unit. 
Nova minicomputers are built by Data General Corporation. 

Data General Corporation offer a set of LSI chips centered on the MicroNova microprocessor. These chips are 
described quite superficially in this chapter since Data General is not actively marketing them as LSI devices. 
Rather, Data General favor the sale of MicroNova microcomputer systems. 

Fairchild manufacture the 9440 microprocessor, which is sold primai^Jy as an LSI device. The 9440 is therefore 
described in some detail, together with standard Nova I/O bus and typical memory bus interface bus logic. 

The Nova minicomputer was designed as a next generation enliancement of tiie PDP-8. The IM6100, which is de- 
scribed in Chapter 1 3 of the Osborne 4 & 8-Bit Microprocessor Handboolc is a single chip implementation of the PDP-8 
Central Processing Unit. 

If you compare the Nova architectures, which we describe in this chapter, with the lM1600,the two products will 
indeed look very different. But conceptually they are similar. Both the Nova and the PDP-8 Central Processing Units 
have few addressable registers; for computing power they rely upon instructions which may perform complex 
sequences of operations. Similarities between the Nova and the PDP-8 will become more apparent if you compare 
these two devices with the CP1600 and the TMS990 — which we have described in Chapters 2 and 3, respectively. 

What is interesting about the Nova minicomputer is that it is one of the most popular in the world; and Data General 
Corporation is the second largest minicomputer manufacturer in the world, despite the fact that many aspects of the 
Nova Central Processing Unit may, on first inspection, appear to be very restricting. 

The MicroNova is manufactured by: 

DATA GENERAL CORPORATION 

Mail Stop 6-58 

Southborough, MA 01772 

The 9440 is manufactured by: 

FAIRCHILD SEMICONDUCTOR 

464 Ellis Street 

Mountain View, CA 94040 

The MicroNova and the 9440 are not the same; differences, however, are small. 

The MicroNova is equivalent to the Nova 3 minicomputer. The Nova 3 is a low-end minicomputer recently in- 
troduced by Data General. Although it is a low-end product, it includes a number of features not found in the basic 
Nova architecture. 

The 9440 reproduces basic Nova architecture — that is, the lowest common denominator of architectural features 
found in any Nova Central Processing Unit. As such, the 9440 lacks a number of logic features provided by the 
MicroNova. The 9440, however, has higher instruction execution speeds. 

Because the MicroNova and the 9440 are very similar, we are going to describe them together in this chapter. 

The MicroNova is manufactured using NMOS LSI technology. The 9440 is manufactured using isoplanar integrated in- 
jection logic (I^L) technology. 

Both products are packaged as 40-pin DIPs. 

The MicroNova requires four power supplies: -4.25V, -I-5V, 4-1 OV and -1-1 4V. The 9440 requires two power sup- 
plies: -I-5V and 4-350 mA. 
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Using a 240 nanosecond clock, the MicroNova executes instructions in 2.4 to 10 microseconds.Using a 100 nanose- 
cond clocl<, 9440 instructions will execute in 1 to 2.5 microseconds. 

A PRODUCT OVERVIEW 

Figure 4-1 illustrates that part of our general microcomputer system logic which has been implemented by the 
MicroNova and the 9440. 

Note that only the MicroNova has a Stack Pointer, and DMA logic. 

Most Nova minicomputers do not have a Stack; the 9440 is a reproduction of.the basic Nova architecture, which is why 
the 9440 lacks a Stack. 

The MicroNova and Nova 3 do contain Stacks, because the addition of the Stack is technologically straightforward, 
while the lack of a Stack had been one of the most distressing features of earlier Nova minicomputers. 

Both the 9440 and the MicroNova have DMA request and DMA acknowledge signals; however, in response to a DMA 
request, the 9440 does nothing except float the System Bus. It is up to you to provide any and all external logic needed 
to actually perform a data transfer via direct memory access. The MicroNova, on the other hand, executes the required 
sequence of I/O operations to actually perform the DMA transfer. That is why in Figure 4-1 DMA logic is shown as 
being present on the MicroNova but not the 9440. 

What about I/O ports? I/O ports interface logic is shown as absent in Figure 4-1 . The I/O port is a microcom- 
puter concept. 

In any microcomputer configuration, you will look upon I/O ports as the ultimate interface between the microcomputer 
system and external logic. You need a conduit via which data bits or signals can be transferred to, or received from 
logic beyond the microcomputer system. Each conduit becomes an I/O port and an I/O port becomes a set of pins, 
which can be addressed as a unit on a support device. Minicomputers take a conceptually different approach to I/O 
operations. To begin with, data is generally transferred to or from the CPU — not signals. The data finishes up on a 
System Bus. Therefore a minicomputer's interface with the outside world consists of an I/O System Bus and a memory 
System Bus. In some cases the two busses are one; in other cases, such as the Nova minicomputers, these two are sep- 
arate and distinct busses. Conceptually, what is important is the fact that the minicomputer anticipates transferring 
data via its I/O System Bus to line printers, disk units, or other substantial devices each of which is capable of having a 
significant amount of local logic. Thus the System Bus is as far as the minicomputer attempts to go when defining its 
interface to the outside world. 

Figure 4-1 , including bus interface logic within the logic of the Central Processing Unit, needs some clarifica- 
tion. As we have just stated, the Nova minicomputer creates two separate System Busses: one for memory, the other 
for I/O devices. All the signals of these two busses originate at card edge pins. There is nothing very expensive about 
adding more pins to the edge of a card, as there is to adding more pins to a DIP. Therefore the Nova System Bus has 47 
signals. Since neither the MicroNova nor the 9440 can have 47 signals, neither of these two devices creates standard 
Nova System Busses; but each device creates its own System Bus which could be used to drive external logic. That is 
why interface logic is shown as being present in Figure 4-1. 
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Figure 4-1. Logic of the Data General MicroNova and the Fairchiid 9440 



There is one further major difference between the MicroNova and the 9440 which is not evident from Figure 
4-1. The MicroNova provides transparent dynamic memory refresh logic. The 9440 has no dynamic memory 
refresh logic. 

The MicroNova, but not the 9440, contains an elementary interval timer capability. Providing interrupt tinner logic 
is enabled, the MicroNova will generate an interrupt request every 20,000 instruction cycles. Using a standard 8.333 
MHz clock, this translates to an interrupt request occurring every 2.4 nnsec. 

Note that the MicroNova and the Nova 3 interval timer logic differ. The Nova 3 provides four programmable interval 
timer options; the MicroNova provides just one. 

NOVA PROGRAMMABLE REGISTERS 

These are the programmable registers of the MicroNova and the 9440: 



ACO 



• Primary Accumulator 



Stack Pointer 
Frame Pointer 



ACI I 

AC2 Accumulator and Index register 
ACS Accumulator, Index register and 
Subroutine Return Address register 

MicroNova Only 
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Data General literature numbers registers and memory words from left to right, rather than as illustrated above, from 
right to left. Also Data General is one of the few minicomputer manufacturers that uses octal numbering. In order to re- 
main consistent with the rest of this book, we will use hexadecimal numbers, and we will number registers from right to 
left; where confusions may arise, we will show both our standard numbers and Data General equivalents. 

ACO and AC1 are typical primary Accumulators. AC2 and AC3 may be used as Accumulators or as Index 
registers. The Jump-to-Subroutine instruction automatically stores the return address in ACS. If one subroutine 
is going to call another (i.e.. you are nesting subroutines), then the calling subroutine must save the contents of AC3 
before itself calling another subroutine. 

Only the MicroNova has a Stack Pointer. The only instructions that access the Stack Pointer are "Push" and "Pop" 
instructions. 

The MicroNova, but not the 9440, also contains a Frame Pointer register. The Frame Pointer register is an address 
buffer used to access the Stack. This may be illustrated as follows: 



MEMORY 



Stack Pointer identifies • 
current top of Stack 



Use Frame Pointer 
to hold important 
Stack addresses 



The Frame Pointer is a buffer register; it is not a Data Counter. There are no instructions that access the memory loca- 
tion addressed by the Frame Pointer. 

Observe that we show no programmable registers identified as Data Counters, even though in Figure 4-1 we show 
Data Counter logic as being present. This is because the Data Counter is another microcomputer concept — in effect, a 
subset of the Index register. If a memory reference instruction specifies direct, indexed addressing with a zero displace- 
ment, then Index Registers AC2 and AC3 are equivalent to Data Counters. 
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NOVA MEMORY ADDRESSING MODES 

Both the MicroNova and the 9440 offer the following standard Nova memory addressing modes: 

1) Base page, direct addressing 

2) Program relative, paged, direct addressing 

3) Indirect addressing 

4) Indirect addressing with auto-increment 

5) Indirect addressing with auto-decrement 

6) Direct, indexed addressing 

7) Pre-indexed, indirect addressing 

These addressing modes have been described in Volunne 1, Chapter 6. 

Nova memory addressing modes are heavily influenced by the fact that every Nova instruction generates a single 16- 
bit object code — -just as the predecessor PDP-8 instructions each generated a single 12-bit object code. Even memory 
reference instructions are confined to 16 bits of object code; therefore the memory reference instruction can only pro- 
vide a short address displacement. Whereas PDP-8 memory reference instructions provide a 7-bit address displace- 
ment, the Nova provides an 8-bit address displacement, which is handled in a much more intelligent fashion. 

Nova instructions that use simple, direct addressing treat the 8-bit displacements as a direct, page zero ad- 
dress, or as a signed binary, program relative displacement. Thus you can directly address the first 256 words of 
memory, or you can address any location within +127 to -128 words of the memory reference instruction itself: 



/ 




0000 
0001 
0002 
0003 

OOFE 
OOFF 
0100 

(xxxx) 4 
(xxxx) 4 
(xxxx) 4 

XXX- 1 

xxxx 
XXXX + 1 

(xxxx) + 
(xxxx) + 
(xxxx) + 




1 






1 






yy can directly address / 
base page \ 










f 






1 






V 












/ 




FF80 (FF80 = -80) 






FF81 (FF81 = -7F) 






FF82 (FF82 = -7E) 


emory reference instruction.. 


V y 


Address displacement 
equals yy 


yy can be added, as a 


\ f 




signed binary number, / 


^ 1 i, 








program relative page 










7D 






7E 






7F 


\ 







Remember, in microcomputer applications, program relative direct addressing is fine for Jump instructions, but is of 
limited value when accessing data memory. When a microcomputer program is stored in read-only memory, program 
relative, direct addressing can be used to read constant data only. 

Nova instructions that specify direct, indexed addressing, compute the effective memory address as the con- 
tents of either AC2 or ACS, plus the 8-bit displacement provided by the instruction object code. The 8-bit dis- 
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placement is treated as a signed binary number. Since the Index registers are 16 bits wide, direct indexed addressing 
allows you to address any memory word. This may be illustrated as follows: 

Accumulator AC2 or ACS 

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 ^ ^ Bit No. 

|X|X|X|X|X|X|X|X|X|X|X|X|X|X|X|X| 




Instruction Code 



15 14 13 12 11 10 9 8 7 6 5 

rr 



4 3 2 10 



n 



l|yQ|z|Y|Y|Y|Y|Y|Y|Y| 



selects AC2 

1 selects ACS 



xxxxxxxxxxxxxxxx 

-ZZZZZZZZYYYYYYYY 
Sum is the effective memory, address 



Indirect addressing may be superimposed on any of the memory addressing options de- 
scribed thus far. indirect addressing is identified by a "1" in bit 10 of the Memory Reference in- 
struction's object code. When indirect addressing is specified, the effective memory address is the 
contents of the directly addressed memory word. 

Let us examine the various Indirect addressing options. First there is page zero indirect ad- 
dressing: 



NOVA 
DIRECT 
MEMORY 
ADDRESSING 



NOVA 
INDIRECT 
PAGE ZERO 
ADDRESSING 



15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 
































^ — 


1236 


y^^^ 




Effective\ 




Memory 1 
MdxvssJ 




^*«-^^ 




^*>-^ 













Arbitrary 

Memory 

MEMOflY Address 



0000 
0001 
0002 
OOOS 



0024 
0025 
0026 
0027 
0030 



Page Zero 
' Indirect addressing 



1235 
1236 
1237 
1240 



In the illustration above, arbitrary, real memory addresses have been selected to make the illustration easier to unders- 
tand. 
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Program relative, indirect addressing may be illustrated as follows: 



NOVA 

INDIRECT 

PROGRAM 

RELATIVE 

ADDRESSING 



15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 



This instruction 
fetched from this 
memory location 
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Indirect, indexed addressing may be illustrated as follows: 



NOVA 
INDIRECT 
INDEXED 
ADDRESSING 



Accumulator AC2 
15 14 13 12 11 10 9 8 7 6 5 4 3 



2 1 0- 



|0|0|0|0|0|0|]|0|1 |o|o|o|i \v\l 




Arbitrary 

Memory 

MEMORY Address 







02BA 






02BB 




7364 


02BC 






02BD 






02BE 


Effectiv^V 




02BF 


Memory 1 
Address/ 










7362 






7363 






7364 






7365 






7366 






7370 



The illustration above arbitrarily uses indexed addressing via Accunnulator AC2. Also the computed effective memory 
address is identical to that which was obtained in the indirect, program relative addressing illustration. 

Observe that Nova indirect addressing logic results in pre-indexed indirect addressing. As described in Volume 1 . 
Chapter 6, this is less desirable than post-indexed indirect addressing. 
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If, and only if indirect addressing has been specified by a "1 " in bit 1 of a Memory Reference in- 
struction's object code, then the contents of the data fetched from memory are treated as a direct 
address, providing the high-order bit of the direct address is 0. If the high-order bit of the address 
is 1, then the address is treated as another indirect address pointer. This may be illustrated as 
follows: 



NOVA 
MULTIPLE 
INDIRECT 
ADDRESSING 




Intwprat Ma mamoiy wMms 



hfterpret as last tnemoiy address 

Note carefully that multilevel indirect addressing will occur only when indirect addressing is specified in the first place. 
If you execute a direct memory reference instruction, data will never be interpreted as an address. 

The Nova indirect addressing logic means that, given a 16-bit indirect address, only 15 bits actually address memory; 
therefore you are limited to a 32,768 word memory address space: 



15 14 13 12 mo 9 8 7 6 J 4 3 2 1 

11 I I I I 1 I I I I I I I I I 



•HtNo. 




32*768 iiwnioiy wioraB 



The Nova minicomputers and microcomputers also provide indirect addressing with auto-increment and auto- 
decrement addressing. If you indirectly address one of the eight memory locations, 001 Oiq through OOI7-15, then the 
contents of the addressed memory location are incremented at the beginning of the memory access. Thus you have in- 
direct addressing with auto-increment. 

If you indirectly address any one of the locations, 001 81 q through 001 Fig then the contents of the addressed memory 
location will be decremented at the beginning of the memory access. Thus you have indirect addressing with auto- 
decrement 

Neither the MicroNova nor the 9440 provide memory mapping logic. Memory mapping is a technique whereby 
more than 32,768 words of addressable memory may be accessed. The Nova 3 minicomputer is capable of supporting 
memory mapping as an option. 

Nova minicomputers have separate memory and I/O device spaces. I/O instructions include six 
bits which identify one of 64 I/O devices. Because Nova minicomputers and microcomputers treat 
I/O devices in a manner that differs significantly from the typical microcomputer, we will defer our 
discussion of I/O addressing until we have looked at pins, signals and System Busses. 



NOVA I/O 

DEVICE 

ADDRESSING 
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MicroNova Only 



NOVA STATUS FLAGS 

Nova minicomputers contain just one status flag, as we would define it, and that is the Carry status. Instruc- 
tions are able to test for a zero or nonzero condition occurring at the conclusion of an instruction's execution, 
but no permanent zero status flag exists. 

MicroNova also has these interrupt related status flags: 

• Interrupt Enable 

• Real Tinne Clock Enable 

• Real Time Clock Request 

• Stack Overflow Request 

The interrupt related status flags do not occur as addressable locations in any Status register; rather they represent flip- 
flops which are set or reset during the course of interrupt handling. 

The interrupt enable bit is a master enable which is set to 1 in order to enable all interrupts. Specific instructions allow 
all interrupts to be enabled or disabled. 

The MicroNova has a Real Time Clock interrupt enable bit and a Real Time Clock request bit. The Real Time Clock ena- 
ble bit must be set to 1 in order to enable Real Time Clock interrupts; as soon as a Real Time Clock interrupt occurs, the 
Real Time Clock enable bit and the Real Time Clock request bit are reset to 0. 

The Stack Overflow request bit is only present in the MicroNova, since only the MicroNova has a Stack. A Stack over- 
flow condition occurs if, following a push operation, the incremented contents of the Stack register have zeros in the 
eight low-order bits. What this implies is that the Stack must reside within a 256-word memory page: 



MEMORY 


Arbitrary 
Memory 
Addresses 




0800 




0801 




0802 




0803 








08FD 




08FE 




08FF ^ 




0900 -♦^St 




0901 \ 




Pushes that increment Stack Pointer 
from XXFF to XYOO will cause a Stack 




09FD Overflow interrupt 
09FE / 
09FF ^Jf 










0AO1 




0A02 



When a Stack overflow occurs, the Stack Overflow request bit is set to 1 and an interrupt is requested. 

MICRONOVA AND 9440 CPU PINS AND SIGNALS 

As we stated earlier in this chapter, minicomputer Central Processing Units are implemented on cards, not 
DIPs; therefore they usually have System Busses containing more than 40 signals. The standard Nova System 
I/O Bus contains 47 signals; furthermore, the Nova System Bus is, in effect, two busses: one communicating 
with memory, while a separate and distinct bus communicates with I/O devices: 
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Table 4-1 briefly defines the functions of bus signals. The I/O Bus is standard for all Nova line computers, while the 
Memory Bus is different for each nnodel. We give the Memory Bus signals of the Nova 2 in Table 4-1. 

Table 4-1. Nova System Bus Signals 

STANDARD NOVA SYSTEM I/O BUS 



SIGNAL 


DIRECTION 


FUNCTION OR INDICATION 


DSO - DS5 


To Device 


Device selection 


DATAO - DATA 15 


Bidirectional 


Data and address lines 


DATOA 


To Device 


Data out to device's A buffer 


DATIA 


To Device 


Data in from device's A buffer 


DATOB 


To Device 


Data out to device's B buffer 


DATIB 


To Device 


Data in from device's B buffer 


DATOC 


To Device 


Data out to device's C buffer 


DATIC 


To Device 


Data in from device's C buffer 


STRT 


To Device 


Start device — clear Done flag, set Busy flag and clear device's INT REQ 
flip-flop 


CLR 


To Device 


Clear device's Busy and Done flags and INT REQ flip-flop 


lOPLS 


To Device 


I/O Pulse — user-defined function 


SELB 


To Processor 


Selected device's Busy flag is set 


SELD 


To Processor 


Selected device's Done flag is set 


RQENB 


To Device 


Enable interrupt or DMA requests 


INTR 


To Processor 


Interrupt request 


INTP 


To Device 


Interrupt priority 


INTA 


To Device 


Interrupt acknowledge 


MSKO 


To Device 


Interrupt mask out 


DCHR 


To Processor 


Data channel request (DMA request) 


DCHP 


To Device 


Data channel priority 


DOHA 


To Device 
To Processor 


Data channel acknowledge 
Data channel mode: 


DCHMO.DCHMI 


DCHMO DCHM1 






H H Data out 






H L Increment memory 






L H Data in 






L L Add to memory 


DCHI 


To Device 


Data channel in 


DCHO 


To Device 


Data channel out 


OVFLO 


To Device 


Overftow: resuh of memory increment or add exceeds FFFF,, 


lORST 


To Device 


dear all I/O devices 



THE NOVA 2 MEMORY BUS 



SIGNAL 


DIRECTION 


FUNCTION OR INDICATION | 


A0-A14 


To Memory 


Memory address lines 




DATA0-DATA15 


Bidirectional 


Memory data lines 




INHIBIT SELECT 


To Memory 


Inhibits selection of memory modiile 




BMEMEN 


To Memory 


Starts memory cycle 




WRITE 


To Memory 


Memory write 




BRMW 


To Memory 


Causes pause between read and write 




WE 


To Merriory 


Enable write after pause in read-pause-vinite cycle 




SYNC ENABLE 


To Processor 


CPU hold control 




RELOAD DISABLE 


To Memory 


Inhibits loading of memory buffer 




WAR- 


To CPU 


Disables other memory modules during write portion of memory 


cycle 


MEM CLOCK 


To Memory 


Memory Ck>ck 




EXTERNAL SELECT- 


To Memory 


Allows module to be selected despite contents of address lines 




EXTERNAL MBLD 


To Memory 


Allows data to be stored in menuxy buffer without starting a memory | 






cycle 





If you are using the MicroNova or 9440 in a new product, then there is no reason why you should create the standard 
Nova System Busses. Providing the signals generated by the MicroNova or the 9440 are adequate for your needs, you 
can interface external logic directly to these two devices. 

Let us first look at the MicroNova pins and signals, which are illustrated in Figure 4-2. 

Two clock signals, 4>1 and 4>2, must be input to synchronize all MicroNova logic. 
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The Memory Bus consists of a 16-bit Address/Data Bus, plus three control signals: SAE, P 
and WE. 



MICRONOVA 
MEMORY BUS 



The Address/Data Bus connects to pins MBO - MB15. P is a synchronization signal, SAE is a read 
enable and WE is a write enable. 

The I/O Bus consists of just four signals: 

1/0 CLOCK synchronizes I/O transfers. 



MICRONOVA 
I/O BUS 



I/O DATA1 and I/O DATA2 are bidirectional data and control signals. 



I/O INPUT identifies the direction of data transfers occurring via I/O DATA1 and I/O DATA2. 

As compared to other microcomputers described in this book, the MicroNova I/O interface is very unusual. Only the 
TMS 9900 I/O logic is at all similar A 1 6-bit I/O data transfer occurs as two 8-bit serial units. This may be illustrated as 
follows: 



I/O CLOCK 



I/O DATA1 



I/O DATA2 



BIT BIT 1 I BIT 2 



I BIT 3 I 



BIT 4 BIT 5 Srr 6 



1"^^/ 



BITO BIT1 BIT2BIT38IT4BrT5Brr6 



JEU 



Eight serial bits are input in less than one microsecond; therefore this method of handling I/O is as fast as the parallel 
data input operations described for other microcomputers. 



Each data transfer is preceded by one of fourxodes generated by levels output via I/O DATA1 and I/O DATA2. These 
are the four codes: 



I/O DATA1 
1 



I/O DATA2 
1 



INTERPRETATION 

Accompanying I/O low pulse may be used to synchronize interrupt requests 

and DMA requests. 

DMA request acknowledge. 

I/O data transfer The transfer direction is specified by I/O INPUT. 

I/O command out. 



Thus every I/O operation will begin with I/O DATA1 and I/O DATA2 bei ng o utput during a low I/O CLOCK pulse . I/O IN- 
PUT wil l be low at this time since data is being output via I/O DATA1 and I/ O DATA2. P rovi ding I/O DA TA1 and ITS ' 
DAT A2 specify a data transfer to follow, the actual data transfer will occur via I/O DATA1 and I/O DATA2 with I/O IN- 
PUT identifying the data transfer direction. 
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MICRONOVA 



Vgs (GROUND) 
nc 

Vdd 

HALT 



CLAMP 
nc 

PAUSE 
<t>2 



PIN NAME 

<t>1. 02 

MBO - MB15 

P 

SAE 

WE 

I/O aOCK 



I/O DATA1, I/O DATA2 



I/O INPUT 



CLAMP 
HALT 



PAUSE 

Vbb Vdd- Vqg. Vss 



DESCRIPTION 
Clock Signals 
Address/Data Bus 
Memory Synchronization 
Memory Read Enable 
Memory Write Enable 
I/O Synchronization 
Data and Control 
Transfer Direction 
Power-On Reset 
CPU Halted 
DMA Request 
External Interrupt Request 
Memory Bus Grant 
Power and Ground 



I/O DATA1 
I/O DATA2 
I/O INPUT 
I/O CLOCK 
Vss (G ROUND) 
MB15 
MB14 
MB13 
MB12 
MB11 



TYPE 

Input 

Bidirectional 

Output 

Output 

Output 

Bidirectional 

Bidirectional 

Output 

Input 

Output 

Input 

Input 

Output 



Figure 4-2. MicroNova CPU Signals and Pin Assignments 

There are two CPU control signals which are not part of either the Memory Bus or the I/O Bus. 

Follo wing pow er-up, the MicroNova CPU will not perform any operation until a high input occurs at CLAMP. 

When CLAMP goes high, int errupts are enabled. Real Time Clock and Stack Overflow interrupt requests are cleared, 
and the CPU is halted. Once CLAMP has been input high, it is ignored until the MicroNova is powered down and then 
powered up again. 

The HALT signal is output by the MicroNova as a high pulse wh ile the MicroNova CPU has been halted — either in 
response to execution of a Halt instruction, or following CLAMP going high. 



There are two MicroNova signals asso ciated with interrupt logic. DMA requests are made via DCH INT while 
any external interrupt is requested via EXT INT. Both the DMA request and the interrup t re quest must b e syn- 
chronized with instruction execution timing. This synchro nization is p rovi ded by I/O D ATA1 and I/O DATA2, as we 
have already described. The DMA acknowledge occurs via I/O DATA1 and I/O DATA2. There is no external interrupt 
acknowledge signal; however, such a signal can be derived from the Memory Bus, as we will describe later in this 
chapter. 



PAUSE is output low by the CPU when devices other than the CPU are permitted to access memory. 

Now look at 9440 pins and signals, which are illustrated in Figure 4-3. 

These pins and signals create a single System Bus. No attempt is made to create separate Memory and I/O 
Busses. 

You may connect a crystal across CP and XTL in order to create a master clock signal, or you may input a clock 
signal via CR 
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MBUSY 
00,01 



PIN NAME DESCRIFHON 

XTL, CP Oock Signals 

SYN Synchronization Signal 

CLK OUT System Oock 

IB0-IB15 Data/Address Bus 

MO - M2 Memory Controls 
Memory Busy 

I/O Control 

INTREQ Interrupt Request 

INT ON Interrupt Enable 

DCH RED DMA Request 

RUN CPU Running 

CARRY Carry Status 

CO- C3 Front Panel/Console Control Signals 

MR Master Reset 

'iNJ' ^CC' '^^^ Power and Ground 



TYPE 

Input 

Output 

Output 

Bidirectional 

Output/ Input 

Input 

Output 

Input 

Output 

Input 

Output 

Output 

Input 

Input 



Figure 4-3. 9440 CPU Signals and Pin Assignments 



The 9440 generates a single synchronizing output (SYN). The CPU clock is output to the 
system via CLK OUT. 



9440 

SYSTEM 

BUS 



IBO - 181 5 provides the 9440 with a multiplexed 1 6-bit Data and Address Bus. This bus car- 

ries addresses to memory an d I/O devices, and it carries bidirectional data between the CPU and 
memory or I/O devices. IBO - IB15 are low true; a low signal level represents a 1 bit. 

IBO is the high-order bus line while IB15 is the low-order bus line. This agrees with Nov a co n venti ons. This 
chapter, and this whole book describe the low-order bit as bit — exactly the reverse of IBO- IB 15. 

There are three control signals on the 9440 CPU-rhemory interface. 

MO is output low to identify a memory read. 
Ml is output low to identify a memory write. 
M2 is output low to identify a memory address being output. 

MO - M2 have open-collector outputs; you can use these lines as inputs to make the timing of a non-memory machine 
cycle conform to the timing of a memory cycle. We will discuss this further when we discuss 9440 timing and instruc- 
tion execution. 



External memory interface logic inputs MBUSY low while it is responding to any memory access. MBUSY is similar to 
the WAIT signals that we have described for other microcomputers; it can be used to make the CPU wait for slow 
memory to respond to a CPU access request. 
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The 9440 has two I/O control signals OO and 01 . These two control signals define I/O and memory accesses as follows: 

01 = OO = Instruction Fetch 

01 = OO = 1 Data Channel Access 

01 =1 OO = Execute I/O Operation 

01 = 1 OO = 1 No I/O 

There are two signals associated with 9440 interrupt logic. 



An external interrupt is requested by inputting INT REG low. 

INT ON indicates whether or not interrupts are enabled. This signal is high when interrupts are enabled; if this sig- 
nal is low, interrupts are disabled. 



A DMA request is made by inputting DCH REQ low. The DMA request is acknowledged by 01 and 00 being output 
low and high, respectively. 

There are seven signals provided by the 9440 specifically to support a front panel or console. 

Two of the front panel or console signals are outputs; these are the RUN and CARRY signals. 

RUN is output high while the CPU is executing programs; it is output low while the CPU is halted. RUN is used to gener- 
ate an appropriate front-panel display light; it is also equivalent to a Halt acknowledge, as described in this book for 
many other microcomputers. 

CARRY represents the condition of the Carry status. This signal is output specifically to drive a front-panel light. 

Five input control signals are provided for switches on a front-panel. Four of these signals are CO, CI. C2 and 

C3; they perform the following operations: 

C3 C2 CI CO FUNCTION 

Display ACO contents at console 

Display AC1 contents at console 

Display AC2 contents at console 

Display ACS contents at console 

Increment Program Counter and then display contents of addressed memory word 

Display contents of addressed memory word 

Load memory from console switches 

Halt 

Deposit switches into ACO 

Deposit switches into AC1 

Deposit switches into AC2 

Deposit switches into AC3 

Load Program Counter from console switches 

Continue/Run 

Increment Program Counter and then load memory from console switches 

No Operation 

The first 9440 devices decoded the C lines in a slightly different manner. The following combinations were 
different operations: 

C3 C2 CI CO FUNCTION 

10 Load Program Counter from console switches 

1 1 Not used 

110 1 Load memory from console switches 

1110 Continue/Run 

MR is the Reset inputto the 9440. When this line is pulled low; the 9440 halts immediately and clears the Interrupt 
Enable flip-flop. Once MR goes high, the CPU will remain in the Halt state until it receives the "Run" command from 
lines C3 - CO. Reset has no further effect on the 9440. it is up to your hardware to load the Program Counter by 
manipulating lines C3- CO and the information Bus. 
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The following sequence is sufficient to start operation of a 9440 system with a "bootstrap' 
program in non-volatile memory: 



9440 
INITIALIZATION 



gYN 



-\r\r\rv~\r\r\ry~\r\r^r^ 



C3 - CO NO OP T LOAD PC T NO OP I RUN I NO OP 



IBO -IB15 



RUN 



STARTING 
ADDRESS 



The hardware must provide the program starting address while issuing the "Load Program Counter" command via the 
C lines. C line codes other than "No Operation" are held for two machine cycles to ensure that the CPU reads them. The 
"No Operation" code between "Load PC" and "Run" gives the CPU time to finish executing the C line command. See 
the data sheets at the end of this chapter for more detailed timing information. 
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Data Output To Destination 




Boolean 
Logic 







Shifter 

and 

Byte Swap 

Logic 



Carry 
Status 
Logic 



Inhibit data output option 

t * 

i Data output 



^ 



iProflran^Sunte^l 



Test 
Carry 



■m 



Carry 
Status 



15 14 


13 12 1110 9 8 7 6 5 4 3 2 1 -• 


ij- 


1 1 1 1 M 1 1 





Arithmetic And Logic Instruction Code 



Figure 4-4. The Nova Arithmetic and Logic Unit 



1514 13 12 11 10 9 8 7 6 5 4 3 2 



1 




S{d|d|t|t|T|h|h|C|C|L|k|K I K|-^- Arithmetic/Logic instruction 



• 000 No sidp 
001 Always skip 

010 Skip if Carry is Zero 

01 1 Skip if Carry is One 

100 Skip on Zero result 

101 Skip on nonzero result 

1 10 Skip on either Carry or result zero 

1 1 1 Skip on CanY and result both nonzero 

Store result in destination Accumulator 

1 Discard result 

00 Preserve current Carry status 

01 Zero Carry 

10 Set Carry to 1 

1 1 Complement current Carry 

These operations are performed on Carry before 
entering the ALU 

00 No operation 

01 Left rotate one bit position 

10 Right rotate one bit position 

1 1 Swap bytes 

These operations are performed on the ALU output 

000 Complement 

001 Twos Complement (Negate) 

010 Move 

01 1 Increment 

100 Add Complement 

101 Subtract 
110 Add 

'"AND OOACO 

Destination Accumulator I 01 AC 1 

Source Accumulator I '" ^^^ 
' 1 1 AC3 



Figure 4-5. Arithmetic/Logic Instruction Object Code Interpretation 
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CPU LOGIC AND INSTRUCTION EXECUTION 

The manner in which the Nova CPU executes instructions differs marl<edly from microcomputers described 
earlier in this book. We will therefore begin our discussion of CPU operations by looking at overall CPU architec- 
ture. 

Our discussion of Nova CPU logic is tied to instruction object code bit patterns; this happens to be the simplest way of 
describing the Nova CPU. We will look at instructions from a programmer's perspective when we examine the Nova in- 
struction set. 

Nova instructions may be divided into these three groups: 

1) Arithmetic, Boolean and logical operations which are essentially internal to the CPU. 

2) Memory reference instructions which offer a variety of memory addressing modes and very little else. 

3) I/O instructions which are designed to allow a considerable amount of intelligence in I/O devices. 
Let us examine each group of instructions and associated CPU logic. 

ARITHMETIC/LOGIC INSTRUCTIONS 

The power of the Nova CPU lies in the fact that many logic functions are implemented sequentially along a 
single data path through the CPU. This is illustrated in Figure 4-4. This figure shows how individual bits of 
arithmetic and logic instruction object codes directly identify the many options available as data makes a single tour 
through the CPU. Figure 4-5 provides specific arithmetic and logic instruction object code interpretations. 

Data to be operated on is always fetched from the Accumulators. Results are always returned to an Accumulator. For 
two-operand instructions, such as binary addition, the Destination Accumulator also serves as the second Source Ac- 
cumulator. For one-operand instructions, such as a complement, there will be one Source Accumulator and one 
Destination Accumulator; the same Accumulator may serve as source and destination. 

As the source and destination definitions would imply, the Nova has no Secondary Memory Reference (or Memory 
Operate) instructions as we define them; for example, you cannot directly add the contents of a memory word to the 
contents of an Accumulator. 

In addition to one or two 1 6-bit data words, the Carry status is input to the Arithmetic and Boolean logic unit. You may 
input the Carry status as is, or you may complement it, reset it to or set it to 1 . If you modify the Carry status, then the 
modified Carry status becomes the new input to the Arithmetic and Boolean logic. 

You may specify one of eight Arithmetic and Logic operations. The Move operation serves both as a Move and a No 
Operation. By specifying the same Accumulator as the source and destination for a Move, Arithmetic and Boolean logic 
is bypassed. Notice that only one Boolean operation, the AND, is provided. This is an inconvenience rather than a prob- 
lem. As discussed in Volume 1 , Chapter 2, you can combine the AND and complement operations to generate an OR or 
an Exclusive-OR. The following Nova instruction sequences substitute for the OR and Exclusive-OR: 

;0R the contents of ACX with ACY. Leave the result in ACY 

COM ACX,ACX Complement ACX 

AND ACX,ACY AND ACX with ACY. Result to ACY 

ADC ACX.ACY Add original ACX. Result to ACY 

;Exclusive-OR ACX with ACY. Leave the result in ACY. 
;ACZ is needed for temporary data storage 

MOV ACY.ACZ Save ACY in ACZ 

ANDZL ACX,ACZ Store twice ACX AND ACY in ACZ 

ADD ACX,ACY Add ACX to ACY 

SUB ACZ,ACY Subtract twice ACX AND ACY 

The 16-bit output from the Arithmetic and Boolean logic, together with the Carry status, passes to the Shifter and Byte 
Swap logic; here the 1 7-bit data unit may be rotated left or right, high and low-order bytes of the 1 6-bit data unit may 
be swapped, or this logic may be bypassed. 

The Shifter and Byte Swap logic outputs 16 bits of data, plus the Carry status. The data and the Carry status may be 
tested separately, and based on one of eight identifiable conditions, the Program Counter contents may be incre- 
mented; this provides conditional skip logic. Figure 4-5 defines the eight conditions that may cause a skip. 

Finally you have the option of preventing results from being stored in the Destination register; this enables conditional 
branch logic without modifying the contents of any Accumulator. 
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In summary, the five operations that can be specified by a single arithmetic/logic instruction may be illustrated 
as follows: 



o 



CARRY 

A) Leave as is 

B) Complement 

C) Set to 1 

D) Reset to 



© 



OPERATION 

A) Complement 

B) ^4egate 

C) Move 

D) Increment 

E) Add Complement 

F) Subtract 

G) Add 
H) AND 



® 







SHIFT 

A) Shift left 

B) Shift right 

C) Swap bytes 

D) None of the above 



SKIP 

A) On Carry = 

B) On Carry = 1 

C) On Result = 

D) On Result ^ 

E) Either Carry or Result is 

F) Neither Carry nor Result are 

G) Always skip 
H) Do not skip 



© 



RESULT 

A) Discard 

B) To destinatkin 



It would take four or five typical microprocessor instructions to perform the same operations that a single Nova instruc- 
tion can perform. 

Arithmetic/logic instruction options are specified in the source program using compound mnemonics. The mnemonics 
are created as follows: 



© O © © 



A) COM 

B) NEG 

C) MOV 

D) INC 

E) ADC 

F) SUB 

G) ADD 
H) AND 



A) 

B) Z 

C) 

D) C 




© 



A) SZC 

B) SNC 

C) SZR 

D) SNR 

E) SEZ 

F) SBN 

G) SKP 
H) 



opr;xyz 



ACs.ACd.nnn 
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The numbers (?) . (T) , (s) , (7) and (b) and the letters A), B), C), D), E), F), G) and H) are keyed to the previous 
illustration. ACs represents 'Source Accunnuiator" while ACd represents "Destination Accumulator". Thus the instruc- 
tion "set carry to 0, then add AC1 contents to AC2, shift the result left one bit, keep the result, but skip on carry set 
"will create the mnemonic: 

ADDZL AC1,AC2,SNC 

All logic associated with the execution of arithmetic/logic instructions is provided by the MicroNova and the 
9440 chips. 



1 2 3 4 5 6 7 8 9 10 11 12 13 14 15-*- Information Bus line 
15 14 13 12 1 1 10 9 8 7 6 5 4 3 2 1 ^ *- Bit No. 
|z|z|z|a|a| I |X|X|D|D|D|D|D|D|D|DV*-Memory Reference instruction 



Displacement 

00 Page addressing 

01 Current page addressing 

10 AC2 indexed addressing 

1 1 ACS indexed addressing 

Direct addressing 

1 Indirect addressing 

00 Select ACO 

01 Select AC1 

10 Select AC2 

1 1 Select AC3 

001 Load selected Accumulator from memory 
010 Store selected Accumulator contents 
in memory 




Figure 4-6. Load and Store Instruction Object Codes 



1 2 3 4 5 6 7 8 9 10 11 12 13 14 15< 
15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 - 



|0|G|0|f|f|j|X|X|d|d|d|d|d|dTdTd 




Information Bus line 

Bit No. 

Jump and Modify Memory instruction 



Displacement 

00 Page addressing 

01 Current page addressing 

10 AC2 indexed addressing 

1 1 AC3 indexed addressing 

Direct addressing 

1 Indirect addressing 

00 Jump 

01 Jump to subroutine 

10 Increment memory and skip if zero 

1 1 Decrement memory and skip if zero 



Figure 4-7. Jump and Modify Memory Instruction Object Codes 



4-20 



1 2 3 4 5 6 7 8 9 JO n 12 13 14 15 

15 14 13 12 ino 9 8 7 6 5 4 3 2 1 

|0| 1 I l|A|A|T|T|T|C|C|ViV|v|v|vlV 




i ii ; 



Information Bus line 

Bit No. 

Input/Output Instruction 



I/O device 
000000 Not Used 



000001) 
111111 \ 



CPU instructions 



00 No operation 

01 Qear Done and set Busy to start device 

10 Clear Done and Busy to idle device 

1 1 Pulse I/O control line 

000 No I/O operation 

001 Input data from A 

010 Output data to A 
Oil Input data from 8 

100 Output data to B 

101 Input data from C 

110 Output data to C 

111 Skip 
Source/Destination register 

00 AGO 

01 AC1 
10AC2 

11 AC3 



Figure 4-8. General Input/Output Instruction Object Code Interpretation 



MEMORY REFERENCE INSTRUCTIONS 

Since the four Accumulators of the Nova CPU must provide data sources and destinations for all arithmetic and 
logic instructions, you will constantly move data between memory and one of the four Accumulators. We have 
already described the Nova addressing modes. Figure 4-6 illustrates memory reference instruction object codes 

and addressing mode specifications. You can load data into any Accumulator, or you can store the contents of any 
Accumulator in memory. 

There are four Jump and Modify Memory instructions. Object codes are given in Figure 4-7. The memory ad- 
dressing options described earlier in the chapter apply also to the Jump and Modify Memory instructions. 

The Jump-to-Subroutine instruction requires special mention: this instruction stores the subroutine return address 
in Accumulator ACS. If you are going to nest subroutines then you must write your own subroutine to create a 
software stack. Note that even the MicroNova, which has a stack, does not use it when a Jump-to-Subroutine 
instruction is executed. 

MicroNova and 9440 chips provide all effective memory address computation logic and reduce memory 
reference instructions, as external logic sees them, to typical address and data transmissions with accompany- 
ing control strobe signals. 

But remember, there is no such thing as a "standard" Nova memory bus. 

INPUT/OUTPUT INSTRUCTIONS 

Figure 4-8 illustrates input/output instruction object code interpretations. 

Every I/O device that communicates with a Nova minicomputer must have a Busy status 
and Done status. These are bidirectional statuses; they are modified by the CPU to control the 
I/O device and they are modified by the I/O device to indicate the status of the I/O operation. 



NOVA I/O 
DEVICE 
BUSY AND 
DONE STATUS 
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This is how the Busy and Done statuses are interpreted: 

BUSY DONE 

Device Idle 

CPU "starts" device by setting Busy to 1 . 

Device resets Busy to and sets Done to 1 when device 

operation is connplete. 

CPU resets Done to idle device, or sets 

Busy for next device operation. 

Illegal 



1 



1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 
15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 

|oh 1 1 |o|oMM hlc|c|v|v|v|v|v|v 




Information Bus line 

Bit No. 

Input/Output Skip instruction 



I/O device 

000000 Not Used 

000001 Not Used 

111111 CPU Skip instruction (see Rgure 17-10). 

00 Skip if Busy is One 

01 Skip if Busy is Zero 

10 Skip if Done is One 

1 1 Skip if Done is Zero 



Figure 4-9. Input/Output Skip Instruction Object Code Interpretation 

You start and stop I/O devices by manipulating device Busy and Done statuses. 

Every I/O device may optionally have up to three individually addressable registers, referred 
to as Registers A, B and C. 

You transfer data between one of the four CPU Accumulators and one of the three I/O device 
registers. 



NOVA 

I/O DEVICE 

REGISTERS 



1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 
15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0- 



|0|lM|A|A|T|T|Tic|c|l|l|l|l|l|lk 

a k ^1 



' Information Bus line 
Bit No. 
' CPU I/O instruction 



00 No operation 

01 Enable Interrupts 

10 Disable interrupts 

1 1 No operation 

' 000 No operation 
001 Read Console switches 
010 Clear I/O devices (MicroNova) 
oil Acknowledge interrupt 

100 Output Interrupt mask 

101 Clear I/O devices (9440) 

1 10 Halt 

1 1 1 Skip as follows: 

00 Skip if interrupt request true 

01 Skip if interrupt request false 

10 Skip if power fail flag Is 1 

1 1 Skip if power fail flag is 

- Source or Destination Accumulator 
OOACO 
01 ACI 
10AC2 
11AC3 



Figure 4-10. CPU Device 3F-|5 Input/Output Instruction Object Code Interpretation 
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Both a status manipulation and a data transfer may be specified by a single 1/0 instruction; these two operations occur 
in parallel and are supported by appropriate control signals on the I/O bus. 

The Nova CPU must be able to poll the Busy and Done statuses of an I/O device, just as most microprocessors read the 
contents of an I/O device Status register. The Nova CPU responds to status condition tests by optionally performing a 
Skip (which means the Program Counter contents are incremented). This variation of I/O instructions is illustrated in 
Figure 4-9. 

Six bits of every I/O instruction object code are used to identify the I/O device being ad- 
dressed. This gives you a total of 64 devices in the I/O device address space. But in order to 
enhance its instruction set, the Nova uses selected I/O device numbers to encode instructions in- 
ternal to the CPU. I/O device numbers 0, 1 and 3f-\Q are reserved for this purpose. I/O device 
3Fi6 selects a number of interrupt related instructions whose object codes are defined in 
Figure 4-10. I/O device numbers and 1 implement instructions illustrated in Figure 4-11. 

You will have to add considerable logic beyond the 9440, or the MicroNova, if you are going to execute all I/O 
instructions described in Figures 4-8, 4-9, 4-10 and 4-11. The only logic provided by the CPU chips themselves sup- 
ports that part of the I/O operation which is exclusively internal to the CPU — and that is not much. The CPU will route 
data to or from the selected Accumulator, if needed, and it will increment the Program Counter in response to a Skip 
true condition. Everything else is the responsibility of logic beyond the CPU chip. 



NOVA I/O 
DEVICE 
ADDRESS 
SPACE 



1 2 3 4 5 6 7 8 9 10 11 12 13 U 15 -^(- Information Bus line 
15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 - ^t- Bit No. 
lOJ 1 |l|X|X|X|X|X|XlX|OJQiO|0|OJ1 H *- CPU I/O instruction 



• 101 1001 Divide 
101 101 1 IVIultiply 
00101 10 Return 
0010100 Save 
YYOOOOO (Move to Frame Pointer \ MicroNova 
YY00010 Move from Frame Pointer / only 
YY01000 IMove to Stacli Pointer 
YY01010 Move from Stack Pointer 
YYOIIOO'Push Accumulator 
W01 1 10 Pop Accumulator 



Accumulator specification 

00 AGO 

01 AC1 
10AC2 
11 AC3 



Figure 4-11. CPU Device 1 Input/Output Instruction Object Code Interpretation 

A NOVA CPU SUMMARY 

If you compare Nova CPU logic with microprocessors described earlier in this book, a number of minicomputer 
characteristics become self-evident. These characteristics have important implications when we look at bus 
signals, interfaces and timing; therefore they must be clearly defined. 

Minicomputer Central Processing Units are more complex than their microprocessor counterparts. Look at the number 
of operations which may be performed during execution of a single Nova instruction; only the 8X300 makes any at- 
tempt to provide such serial logic. The microprocessor CPU architect has been severely restricted by the fact that only a 
limited amount of logic can be put on a chip without drastically affecting chip yield — and therefore the price of the 
microprocessor. When minicomputers were designed, making CPU logic more complex increased the size of the CPU 
card, or cards, which had some effect on eventual product price, but nothing like the microprocessor price escalations 
that result from low chip yields. 

Thus unconstrained by logic limitations, minicomputer CPU architects also designed complex system busses, requiring 
equivalently complex logic within I/O devices attached to the system busses. For example, consider the fact that Figure 
4-5 defines 32,768 different Register-Register Operate instructions, while the instruction format in Figure 4-8 
assumes an I/O System Bus that can simultaneously manipulate I/O device status while transferring data. 
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These are formidable burdens placed on the designer of a chip which is supposed to reproduce the Nova CPU — with 
the result that chip designers have elected to tackle only part of the task. Both the MicroNova and the 9440 terminate 
at 40-pin DIPs; their busses are, in consequence, less than the standard Nova System Busses. 

9440 TIMING AND INSTRUCTION EXECUTION 

We will now examine 9440 instruction timing in detail. 

9440 instructions and internal logic are timed by a master 10 MHz clock signal. Instructions are executed in 
machine cycles. This is the number of clock periods per machine cycle: 

Memory read/instruction fetch - 15 clock periods i Depends on actual 

Memory write - 15 clock periods ) memory timing 

I/O data in - 10 clock periods 

I/O data out - 10 clock periods 

Let us begin by looking at timing for an instruction fetch or a memory read; these two 
machine cycles have the timing illustrated in Figure 4-12. 

At the end of clock period 2, the three memory control signals MO, Ml and M2 are output with 
levels that identify the memory access which will be performed during the curr ent machine cycle. 
For a memory read or instruction fetch, MO and Ml are output low while Ml remains high. 



9440 

INSTRUCTION 

FETCH 



9440 

MEMORY 

READ 




Figure 4-12. 9440 Memory Read/Instruction Fetch Timing 

An instruction fetch and a memory read are differentiated by signals 00 and 01 ; these signals are both low for an in- 
struction fetch and bo th h igh for a memory read. The address of the memory location to be ac cesse d is output on the 
Information Bus (IBO - IB1 5) beginning at the end of clo ck period 8. At the end of clock period 9 SYN is output low; ex- 
ternal logic must use the high-to-low transition of SY N as a strobe to latc h an add ress off the Infor mation B us. External 
logic must also use the high-to-low transition of SYN as a trigger to input MBUSY low to the 9440. MBUSY mu st be in- 
put low until addressed data has been read from memory and is stable on the Information Bus. At that time MBUSY 
goes high again. When MBUSY goes high, the 9440 will read da ta off th e Information Bus. If the Memory Read 
machine cycle is to execute in the minimum 15 clock periods, then MBUSY must be low for one clock period only. 
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Figure 4-1 2 shows the CPU driving the Information Bus during the first two cloci< periods of the machine cycle follow- 
ing the Read or Instruction Fetch cycle. Following an Instruction Fetch, the 9440 will output the instruction address; 
after any other memory read, the CPU will output the data just read. 

During a memor y rea d that is not an Instruction Fetch, data should be available slightly beyond the ending transition 
(lovy-to- high) of SYN. During an Instruction Fetch, the CPU reads the instruction one clock period after it detects 
MBUSY high; however, during any other memory read, the 9440 reads the data two clock periods later, on the same 
clock edge that generates the low-to-high transition of SYN. This may be illustrated as follows: 




CPU de tects If cycle is an 

MBUSY high Instruction Fetch, 
CPU reads data here 



If cycle is a non-Fetch 
memot7 read, CPU reads 
data here 



Thus, on a non-Instru ction Fetch memory read, data should be available 15 to 20 nanoseconds beyond the low- 
to-high transition of SYN. 
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MBU SY is a signal used by external mennory interface logic to synchronize itself with the C PU. If MBUSY is low while 
SYN is h igh early in any memory access machine cycle, then the high-to-low transition of SYN will be delayed until 
MBUSY goes high. For a Memory Read or Instruction Fetch machine cy cle, the t railing edge of the low MBUSY pulse 
also acts as an end- of-machine-cycle trigger. Three clock periods after MBU SY's low-to-high transition, the machine 
cycle ends and SYN goes high again. Here is an example of MBUSY and SYN interaction during termination of a Memo- 
ry Read or Instruction Fetch machine cycle: 



r\j\T\j\..^ 




MBUSY 




MBUSY and SYN interaction at the high-to-low SYN transition may be illustrated as follows; 

N is greater than 9 




Machina Cycia 1 




Figure 4-13. 9440 Memory Write Timing 

Every instruction's execution will begin with an instruction fetch machine cycle. This machine cycle will be 
followed by internal operations, another memory read, a memory write, an I/O read, or an I/O write. 

If the instruction to be executed requires internal operations only, that is, it is an arithmetic/logic instruction, then 
internal operations are executed during clock periods 1 through 8 of the next machine cycle — which must be 
another instruction fetch machine cycle. 
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If a memory read operation is to be performed, then another machine cycle is executed, exactly equivalent to 
Figure 4-12. 

If a memory write is to be performed, then two machine cycles must follow the instruction fetch. During the first 
machine cycle the external mennory address is output. During the second machine cycle data to be written t o me mory 
is output. Timing is illustrated in Figure 4-13. This figure is self-evident. During the first machine cycle only M2 is low 
since a memory address is being outpu t wit hout a read or a write operation occurring during the same machine cycle. 
During the second machine cycle only Ml is output low since a memory write operation alone will occur. 

During both machine cy cles of a Memory Write operation, MBUSY acts as a syn chronizing sig nal, h owever only the 
high-to-low transition of MBUSY can modify instruction execution time. If MBUSY is low prior to S YN ma king its high- 
to-low transition, th en the S YN high-to-low transition will be delaye d until M BUSY goes high. Once SYN goes low, the 
processor waits for MBUSY to go low; three clock periods after t he MBUS Y high-to-low trans ition, the memory write 
machine cycle will end. The subsequent low-to-high transition of MBUSY has no effect on the SYN signal, or on inter- 
nal CPU operations. 

The only memory addressing modes that change instruction execution time are indirect addressing and indirect 
addressing with auto-increment or auto-decrement. 

Each level of indirect addressing is equivalent to an additional memory read and an additional memory write. In order to 
compute instruction execution times for memory references with indirect addressing, therefore, add one memory read 
machine cycle and one memory write machine cycle for each level of indirection. 

Recall that memory locations IOiq through 1F-|6 are used to store addresses which, when accessed indirectly, will be 
incremented or decremented. When you use indirect addressing and specify a memory location from lO-ig through 
17-|5, the address fetched from the specified location will be incremented. An indirect address fetched from locations 
I816 through ^f'\Q will be decremented. The increment or decrement operation requires the memory address to be 
loaded into the CPU, incremented or decremented, then written back out. Loading the address into the CPU is a routine 
part of any indirect addressing sequence; however, writing the address back out represents an additional step requir- 
ing an additional memory write machine cycle. This may be illustrated as follows: 



Machine Cycle 1 

Instruction 

fetch 



Machine Cycle 2 

Fetch address 

from location 

IO16-IF16 



Machine Cycle 3 

Increment or 

decrement 

address and 

write address 

back 



Machine Cycle 4 

Perform memory 

access 

(read or write) 



Memory Write 

The increment or decrement and Skip-if-Zero instructions require an instruction fetch, a memory read and a 
memory write machine cycle. Timing may be illustrated for direct memory addressing as follows: 



Machine Cycle 1 

Instruction 

fetch 



Machine Cycle 2 

Fetch data 

from memory 



Machine Cycle 3 Machine Cycle 4 

Increment or Increment 

decrement data Program Counter 
and write if needed 

data back 

Memory Write 

Let us now look at I/O instruction execution. 

There are no special I/O device select or control signals output by the 9440, rather external I/O devices must 
have select logic which is created by decoding instruction object codes on the Information Bus. This is done by 
decoding the three high-order Information Bus lines during an instruction fetch, as characterized by OO and 01 both 
low. The three high-order Information Bus lines will at this time be 01 1 if the instruction to be executed is an I/O in- 
struction. If these conditions are met, then the six low-order Information Bus lines must be decoded by device select 
logic. If the device code is 3Fiq, then all I/O devices must be selected simultaneously; for this to occur a special over- 
riding device select signal must be created in response to device code 3F. If device code OOig occurs, then no device 
should be selected; this requires no special select logic, rather it means that no external device sliould have the address 
OO1 6- If any device code other than 00-| 5. or 3F-| g appears on the six low-order Information Bus lines, then one external 
device's select logic should go true. 
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An actual example of I/O device logic is given later in this chapter. 

If devic€^^ode3Fi6 has been output, then one of the operations defined by Figure 4-10 is about to occur. A significant 
amount of Eternal logic associated with execution of these instructions may be required. A specific implementation 
consistent with standard Nova 1200 I/O interface logic is given later in this chapter. Alternatively, you may create a 
variety of individual control signals unrelated to the standard Nova I/O bus by suitably decoding I/O instruction object 
code bits 10 through 6. 

An I/O instruction which identifies a specific device further identifies the I/O operations which are to occur, via bits 10 
through 6 of the instruction object code (Information Bus lines IB5 through IB9). Figures 4-8 and 4-9 show the I/O 
operations which may be specified. If data is to be input or output, then timing will conform to Figures 4-14 and 

4-15. •• But a significant amount of parallel control logic will accompany any I/O data transfer. We will shortly describe 
logic which implements a typcial I/O device interface. 

If you wish to slow down 9440 I/O machine cycles, you can do so by using any one of the lines KlO 
- Ml. Normally, the CPU outputs a high level on these three lines during an I/O machine cycle. 
However, if external logic pulls one of these lines low early enough in the I/O cycle, the 9440 will 
require the interaction of SYN and MOUSY to complete the machine cycle, just as if it were a 
memory cycle. You must pull the M line low before the sixth clock period of the I/O machine cycle. 



9440 I/O 

WAIT 

STATES 



MO, Ml, orM2 




Pull MO, Ml, orM2 

low before this clock 

to extend length of 

I/O cycle. 



9440 CPU reads the 
M lines at this time. 



You can complete the machine cycle by manipulating MBUSY or by releasing the M line. 

An 1/0 Skip on Busy or Done instruction, as illustrated in Figure 4-9. requires the addressed 1/0 device to return Busy 
and Done statuses to the CPU. The addressed 1/0 device returns these statuses on the two high-order Information Bus 
lines IBO and IB1, respectively, with timing conforming to Figure 4-14. 

See Table 4-4 for the sequences of machine cycles involved in 9440 command execution. 
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Figure 4-14. 9440 I/O Data Input Timing 
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Figure 4-15. 9440 I/O Data Output Timing 
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MICRONOVA AND 9440 INTERRUPT PROCESSING 

At the most elementary level, the MicroNova and the 9440 respond to interrupts in a very simple way. 

External logic requests an interrupt by inputting a low signal via INT REQ. 

Providing interrupts are enabled, the CPU acknowledges the interrupt upon completing execution of the current 
instruction; the CPU disables its own interrupt logic, saves the Program Counter contents in memory location 
0000, then jumps indirect via location 0001. Thus memory location 0001 must contain the address of the first inter- 
rupt service routine instruction. 



Return address following interrupt service - 
Starting address for interrupt service routine- 



Interrupt acknowledged here ■ 
This instruction will be executed ■ 
following interrupt service 



Interrupt service routine starts here - 



0000 
0001 
0002 
0003 
0004 
0005 



xxxx-1 
xxxx 
xxxx + 1 
xxxx + 2 
xxxx + 3 



yyyy-1 

yyvv 

yyyy+ 1 
yyyy +2 



A single interrupt service routine will be executed in response to any external interrupt. In order to discriminate 
between interrupts, the interrupt service routine must identify the source of the interrupt, then jump to an appropriate 
individual program. This may be illustrated as follows: 



Device 1 
Interrupt 
Service 
Routine 



Device 2 
Interrupt 
Service 
Routine 



Initial 
Interrupt 
Service 
Routine 



Device 3 
Interrupt 
Service 
Routine 



Device 4 
Interrupt 
Service 
Routine 



Device 5 
Interrupt 
Service 
Routine 



iiUi 
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There will be a separate device interrupt service routine for every I/O device capable of representing an interrupt. 

There are many ways in which the initial interrupt service routine may identify the interrupting I/O device in a 
multiple interrupt configuration. 

The most primitive method used to identify an interrupting I/O device is to test the device's Done status. Standard 
Nova protocol requires an I/O device to request an interrupt when it sets its Done status. This may be illustrated as 
follows: 



nterrupt 
Request 


Busy 


Done 


False 
False 
True 



1 



Device idle 

Start I/O operation 

1 End I/O operation 



Primitive I/O device interface logic will request an interrupt by applying a low signal at INT REQ when it sets its Done 
status high. Now the initial interrupt service routine will execute a sequence of "Skip on Done False" instructions in 
order to identify the highest priority interrupting device. This may be illustrated as follows: 




The order in which the initial interrupt service routine program logic tests device Done statuses becomes interrupt 
priority. You can modify this priority sequence at any time simply by changing the program. 

A faster method of identifying an interrupting device is to daisy chain the interrupting devices. Daisy chain logic 
has been described in Volume 1, and again in Chapter 6 of the Osborne 4 & 8-Bit Microprocessor Handbook (in con- 
junction with the 8048). Daisy chains are resolved by an interrupt acknowledge signal; but there is no interrupt 
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acknowledge signal output by the MicroNova or the 9440; rather an interrupt acknowledge instruction is 
executed. This is an I/O instruction addressing device 3Fi g; bits 1 0, 9, and 8 (IB5, [B6, and lB7) of the instruction object 
code must be decoded in order to create an interrupt acknowledge signal. Here is appropriate logic: 




INTA 



MBUSY 



Recall that the Information Bus is low true; that is, a low logic level represents a bit value of 1. T o en sure that INTA is 
generated only when a valid instruction code is on the Infornnation Bus, it should be qualified by SYN low and MBUSY 
low-to-high transition. This is illustrated in Figure 4-16. 

The highest priority interrupting device identifies itself by placing its device code on the Information Bus lines. The 
CPU stores the device number in one of the four Accumulators. Thus the interrupt acknowledge instruction is an I/O 
Data In instruction. Interrupt acknowledge timing is illustrated in Figure 4-16. 

Interrupt enable and disable logic exists separately at the CPU and at external I/O devices. 

At the CPU all interrupts are disabled as soon as an interrupt is detected. You can disable interrupts at any other time 
by executing a disable interrupt instruction (NIOC CPU). 

In order to enable interrupts you must execute an interrupt enable instruction (NIOS CPU); when an NIOS CPU instruc- 
tion is executed, interrupts are enabled following execution of the next instruction. This next instruction will usually be 
a Return instruction: 



NIOS CPU ;Enable interrupts 

JMP @0 ;Return from interrupt service routine 

;lnterrupts are now enabled 

When nested interrupts are not allowed, all interrupts are disabled following the interrupt detection; interrupts remain 
disabled until the end of the interrupt service routine. You terminate the interrupt service routine with the two instruc- 
tions illustrated above; one re-enables interrupts, the other returns from the interrupt service routine. Interrupts are not 
actually re-enabled until after the Return instruction has been executed; this prevents pending interrupts from being 
acknowledged before you have finally exited the current interrupt service routine. 
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Figure 4-16. 9440 Interrupt Acknowledge Instruction Execution Tinning 



If you want to nest interrupts then you must execute an interrupt enable instruction within the interruptable interrupt 
service routine. But make sure that you do not re-enable interrupts until the initial interrupt service routine has ex- 
ecuted; remember, the initial interrupt service routine is determining the source of the interrupt — and it makes no 
sense to allow another interrupt to occur until this determination has been completed. 

You can disable interrupts selectively at external devices that have local interrupt disable logic. This is done 
using the Mask Out instruction (MSKO); MSKO is another I/O instruction addressing device 3F15. The MSKO in- 
struction outputs data from one of the CPU Accumulators onto the Information Bus. Every I/O device capable of having 
its interrupt logic disabled must be connected to one of the Information Bus lines. When the MSKO instruction is ex- 
ecuted, the I/O device must first decode the MSKO instruction in order to activate its interrupt disable logic; subse- 
quently, if the Information Bus line to which device interrupt disable logic is connected is low, then interrupt request 
logic must be disabled locally. Timing is illustrated in Figure 4-17. 

In order to re-enabie interrupts at any external device you output a new mask with a high level on the Information Bus 
line to which the device's interrupt disable logic is connected. 

Interrupt logic again demonstrates the minicomputer emphasis of the Nova. We have assumed that an external 
device capable of requesting interrupts can decode I/O instruction object codes on the Information Bus and have a con- 
siderable amount of logic associated with Busy, Done and Interrupt request flags. 
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Figure 4-17. 9440 Mask Out Instruction Execution Tinning 

MICRONOVA AND 9440 DIRECT 
MEMORY ACCESS LOGIC 



MicroNova and 9440 direct memory access logic differ markedly. 

in both cases external logic represents a DMA access by inputting a low signal via DCH REQ. 

The MicroN ova responds by acknowledging the DMA request. This is done by outputtin g a high I/O DATA1 with a low 
I/O DATA2 signal. External logic then identifies the direction of the data transfer via the I/O INPUT control signal. Sub- 
sequently, MicroNova logic performs the entire DMA transfer by creating appropriate I/O Bus and Memory Bus signal 
sequences — but only data may be transferred in only one direction. 
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The 9440 has a more primitive DMA capability, it responds to DCH INT by outputting lines 01 and 00 low and high, 
respectively, and floating the Data Bus. External logic must implement the actual DMA transfer. 

Standard Nova protocol allows four DMA operations to be defined by external logic via the DCHMO and DCHM1 I/O 
bus signals. These are the four DMA operations that may be defined: 



DCHMO DCHM1 

Add to memory 

1 Data in 

1 Increment memory 
1 1 Data out 

The MicroNova, as we have already stated, handles data in and data out only; increment memory and add to memory 
are not available. 

The 9440 on the other hand, does nothing in response to a DMA request other than float the Information Bus. All 
external logic associated with DMA operations must exist outside the 9440 chip. We will describe suitable 
logic later in this chapter. 

THE MICRONOVA AND 9440 INSTRUCTION SETS 

Table 4-2 summarizes the instruction sets for the MicroNova and the 9440. Observe that there are some instruc- 
tions available with MicroNova that the 9440 lacks. 

The power of the Nova instruction set is derived from the fact that many instructions perform multiple operations. 
Register Operate instructions, for example, allow you to set, or reset or complement a Carry status before the specified 
operation is performed. Primary Memory Reference and Register Operate instructions allow you to also perform data 
shifts, or to swap the high and low-order bytes of the data word being moved or generated. 

Primary Memory Reference and Register Operate instructions also allow you to perform a conditional skip based on the 
results of the operation. 

It is the ability of the Nova instruction set to perform a combination of operations, during a single instruction's execu- 
tion, that makes the instruction set so effective. 

THE BENCHMARK PROGRAM 

Our benchmark program may be illustrated as follows for the MicroNova and the 9440: 

LOAD WORD COUNT COMPLEMENT INTO AC2 
LOAD lOBUF BASE ADDRESS INTO AUTO- 
INCREMENT LOCATION 

LOAD ADDRESS OF FIRST FREE TABLE WORD 
INTO AUTO-INCREMENT LOCATION 
LOAD NEXT BYTE FROM lOBUF 
STORE IN NEXT TABLE WORD 
INCREMENT WORD COUNT SKIP IF ZERO 
RETURN FOR MORE 

RETURN NEW ADDRESS OF FIRST FREE TABLE 
WORD 

This benchmark program uses indirect addressing with auto-incrementing in order to sequentially access lOBUF and 
TABLE. We begin the program by loading the word count (CNT) into Accumulator 2, and table base addresses into 
memory words 1 0-j 5 and 11 1 6- We assume that the address of the first free word in TABLE is stored in the first word of 
TABLE; thus we can fetch the address of the first free TABLE word by executing a load to Register with indirect ad- 
dressing. 

Data is moved by a four-instruction loop. Two instructions load data from lOBUF and store data in TABLE using indirect 
addressing with auto-increment. Next we increment the counter stored in Register 2 and skip the following instruction 
upon detecting a zero count. The following instruction is a jump back to the beginning of the loop. 

The final two instructions simply restore the new address for the first free TABLE word into the first word of the TABLE. 

The benchmark program makes no assumptions. The source and destination tables may be any size and any number of 
data words may be transferred, limited only by the available memory space. 
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The following notation is used in Table 4-2. 

An "X" in the colunnn labeled "9440" indicates that the instruction is available on the 9440 CPU. 
AC Any of the four Accumulators. 

ACX A specific Accumulator For exannple, AC1 is Accumulator 1. 

C Carry status 

D An Accumulator which serves as the destination for the results of an operation. 

DEV A 6-bit device code. 

DEVX A specific device register. For example, DEVA is Device Register A. 

DEVBD Device Busy-Done flags. 

EA Effective address determined by @DISP (,IX ). 

FP Frame Pointer (not present in 9440). 

ION Interrupt ON flag 

PC Program Counter 

PM Priority Mask 

S An Accumulator which serves as the source of an operand. 

SP Stack Pointer (not present in 9440). 

(CS#) Represents three options which are used by the Register-Register operations. 

C is a 2-bit field which determines the carry state prior to the ALU operation. 
Coded Character Result Bits Operation 

No operation 
Set carry to 
Set carry to 1 
Complement carry 
For example, ADDO 2,2 would set carry to 1 before adding AC2 to AC2. 
S is a 2-bit field which determines how the result of the ALU will be shifted. 
Coded Character Result Bits Operation 
option omitted 00 No shift 

L 01 Shift result and carry left 

one bit 
R 10 Shift result and carry right 

one bit 
S 1 1 Swap result bytes 

For example, MOVS 1,2 would swap the bytes of AC1 and store into AC2. 
# is a 1-bit field which determines whether the result is stored in ACD. 
Coded Character Result Bits Operation 
option omitted Load result into ACD 

# 1 Do not load result into ACD 

For example, NEGOL# 1,2 would set carry to 1 then negate AC1 , shift the result and carry left one bit 
but would not store into AC2. 

A 2-bit I/O command whose meaning depends on whether the CPU or another device is being 
referenced. 

Device 

No operation 

Start device by setting Busy to 1 

and Done to 

Idle device by setting Busy to 

and Done to 

Pulse a special device dependent 

line 



CPU 
No operation 
Set Interrupt 
On to 1 


f 

do 

01 


Set Interrupt 
On to 


10 


No operation 


11 
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000 


No operation 


001 


Always skip 


010 


Skip if Carry = 


oil 


Skip if Carry = 1 


100 


Skip if result = 


101 


Skip if result f 


110 


Skip if either carry or result = 


111 


Skip if both carry and result =f 



(,SKCND) A 3-bit skip-on-condition field which is used by the Register-Register Operate instructions. 

Coded Character Result Bits Operation 
option omitted 
SKP 
SZC 
SNZ 
SZR 
SNR 
SEZ 
SBN 
(@ ) DISP (,IX) Generates the address EA 

@ is the indirect bit. If @=1 then indirection is specified. 
DISP is an 8-bit address value. 

(IX) is a 2-bit field which indicates the addressing Mode: 
Bits are Mode 

00 Zero page addressing. DISP is an unsigned address 
between and 256. 

EA = DISP 

01 PC relative addressing. DISP is a signed two's 
complement address displacement. 

EA = DISP-h[PC] 

10 Indexed addressing via AC2. DISP is a signed 
two's complement address displacement. 

EA = DISP-I-[AC2] 

1 1 Indexed addressing via AC3. DISP is a signed 
two's complement address displacement. 

EA = DISP-I-[AC3] 
(t) A 2-bit I/O test field whose meaning depends on whether the CPU or another device is referenced. 

CPU ± Device 

Test for Interrupt On=1 00 Test for Busy=1 

Test for Interrupt On=0 01 Test for Busy=0 

Never skip 10 Test for Done=1 

Always skip 1 1 Test for Done=0 

x<y,z> Bits y through z of the quantity x. [ AC]<5,0> is the low six bits of the specified Accumulator. 

[ ] Contents of location enclosed within brackets. If a register designation is enclosed within the brackets, 

then the designated register's contents are specified. If a memory address is enclosed within the 

brackets, then the contents of the addressed memory location are specified. 
[[ ]] Implied memory addressing; the contents of the memory location designated by the contents of a 

register. 
A Logical AND 

■^ Data is transferred in the direction of the arrow. 

Under the heading of STATUS in Table 4-2, an X indicates statuses which are modified in the course of the instruc- 
tion's execution. If there is no X, it means that the status maintains the value it had before the instruction was ex- 
ecuted. 
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Table 4-2. MicroNova and 9440 Instruction Set Summary 



TYPE 


MNEMONIC 


OPERANOIS) 


BYTES 


STATUS 
C 


9440 


OPERATION PERFORMED 




NIO [f) 


DEV 


2 




X 


[DEVBD] -f 




DIA (f) 


ACDEV 


2 




X 


Set the device's Busy and Done flags according to I/O command. 
[AC] — [DEVA] 
[DEVBD] — f 




DIB(f) 


ACDEV 


2 




X 


Read device's A buffer into Accumulator. Set the device Busy arid Done flags. 
[AC] - [DEVB] 
[DEVBD] -f 


O 


Die (f) 
DOA(f) 


ACDEV 
ACDEV 


2 
2 




X 
X 


Read device's B buffer into Accumulator. Set the device Busy arid Dorie flags. 
[AC]-[DEVC] 
[DEVBD]— f 

Read device's C buffer into Accumulator. Set the device Busy and Done flags. 
[DEVA] — [AC] 
[DEVBD] -f 




DOB (f ) 


ACDEV 


2 




X 


Write Accumulator into device's A buffeir. Set the device Busy and Done flags. 
[DEVB] -[AC] 
[DEVBD] — f 




DOC(f) 
SKP{t) 


ACDEV 
DEV 


2 
2 




X 
X 


Write Accumulator into device's B buffer. Set the device Busy and Done flags. 
[DEVC]-[AC] 
[DEVBD] -f 

Write the Accumulator into device's C buffer. Set the Busy and Done flags. 
If T is true for DEV, [PC] — [PC] + 1 




lORST 








X 


Skip if I/O test true. 
[PM]-0 
[ION]— 10, 

The Busy and Done flags in all I/O devices are set to 0. The Priority Mask is set to and 

interrupts are turned on. 



Table 4-2. MicroNova and 9440 Instruction Set Summary (Continued) 



tYPE 


MNEMONIC 


OPERAND(S) 


BYTES 


STATUS 


9440 


OPERATION PERFORMED 


C 


PRIMARY 

MEMORY 

REFERENCE 


LDA 
STA 


AC,(")DISP(,IX) 
AC,(")DISP(,IX) 


2 
2 




X 
X 


(AC]-[EA] 

Load contents of memory to Accumulator. 
[EA] - [AC] 

Store contents of Accumulator Into memory. 


iU 

< 
K 
ili 

Q. 

o 

K 
M 

5 

lU 
K 

K 
lU 

t- 

w 
5 

lU 

DC 


ADD(CS#) 

SUB(CS#) 

NEG(CS#) 

ADC (OS A/) 

MOV(CS'/) 
INC(CS/') 
COM(CS«) 

AND(CS'') 


S.O(SKCND) 

S,D(,SKCND) 

S,D (.SKCND) 

S,D (.SKCND) 

S.D (.SKCND) 
S.D (.SKCND) 
S.D (.SKCND) 

S.D (.SKCND) 


2 

2 

2 

2 

2 
2 
2 

2 


X 

X 

X 

X 

X 
X 
X 

X 


X 

X 

X 

X 

X 
X 
X 

X 


[D]-[D)+ [S] 

Add contents of Source register to contents of Destination register. Perform the specified 

options. 
[D]-[D]- [SI 

Subtract contents of Source register from contents of Destination register. Perform the 

specified options. 
[D] — [¥] + 1 (twos complement) 

Place twos complement of the Source register contents In the Destination register. Perform 

the specified options. 
[D]-[D]+[S] 

Add the ones complement of the Source register contents to contents of Destination register. 

Perform the specified option. 
[D)-[S) 

Move contents of Source register to Destination register. Perfbrfn the specified options. 
[Dl-[S1 + 1 

Place Incremented Source register contents into Destination register. Perform specified options. 
[D] - [S] 

Complement the Source register contents, then move to Destination register. Perform 

specified options. 
[D]-[D] A [S] 

AND the Source register contents with the Destination register contents. Perform specified 

options. 



Table 4-2. MicroNova and 9440 Instruction Set Sumnnary (Continued) 



TYPE 


MNEMONIC 


OPERAND (S) 


BYTES 


STATUS 


9440 


OPERATION PERFORMED 


C 


REGISTER-REGISTER 

OPERATE 

(CONTINUED) 


MUL 
DIV 




2 
2 


X 




[ACO] -(( [AC1]» [AC2])+ [ACOD <31,16> 
(ACIl— (( [AC11* [AC2])+ [ACO]) <15,0> 

Multiply contents of AC1 by contents of AC2 and add contents of ACO to result. 
[AC1] -( [ACd],[AC1])/[AC2] (quotient) 
[ ACO] - ( [ ACO], [ AC 1 ])/ [ AC2] (remainder) 

Divide the 32-bit quantity contained in ACO (high order) and AC1 (low order) by the 

contents of AC2. 




PSHA 
POPA 
SAV 

MTSP 
MTFP 


AC 
AC 

AC 
AC 


2 
2 
2 

2 
2 






[SP]-[SP]+1; [[SP]]-[AC1 

Push the Accumulator onto the Stack. 
[AC] — [[SP]; [SP] — [SP]- 1 

Pop the top of the Stack to the Accumulator. 
[[SP]+1]-[AC0] 
[(SP] + 2]-[AC1] 
[[SP] + 3]-[AC2] 
[[SP] + 4]-[AC3] 
[[SP] + 5] <14,0> -[PC] 
[[SP] + 5] <15> -[C] 
[SP]-[SPi + 5 
CFP]-[SP] 

Save a return block in the Stack. 
[SP3-[AC] <14,0> 

Move the low 15 bits of the Accumulator to the Stack Pointer. 
[FP] — [AC] <14,0> 

Move the low 15 bits of the Accumulator to the Frame Pointer. 



Table 4-2. MicroNova and 9440 Instruction Set Summary (Continued) 



TYPE 


MNEMONIC 


OPERAND(S) 


BYTES 


STATUS 


9440 


OPERATION PERFORMED 


C 


5 

Ul 


MFSP 
IVIFFP 


AC 
AC 


2 
2 






[AC] <14,0> <- [SP] 
[ACl <16> —0 

Move the Stack Pointer to k>w 15 biu of Accumulator. 
[AC] <14,0>-[FP] 
[ACl <16><-0 

Move the Frame Pointer to the Accumulator. 


a. 

3 


JMP 
JSR 

RET 


(")DISP(.IX) 
^ (")DISP(,IX) 


2 
2 

2 


X 


X 
X 


[PCl-EEA] 

Branch imconcNtkNwI. 
[ACS] ^ [PCI + 1 
[PCl'-EEAl 

Branch to subroutine. 
(SPJ-(FP] 
[C]-[[SP]]<16> 
[PC]-[[SP11 <14,0> 
[AC3)-[[SP1-1] 
[AC2]-[[SPl-2l 
[AC1]-[[SP1-31 
[AC21 <- [[SP] - 4] 
[SP]-[SP]-5 

Return from subroutine and pop a return block off the Stack. 


UJ 


RTCEN(f) 
RTCDS(f) 




2 
2 




X 
X 


[ON] -f 

Enable Real Time Oock then set ION via I/O command. 
[ON] -f 

Disable Reel Time Ckxsk then set ON via I/O command. 



Table 4-2. MicroNova and 9440 Instruction Set Summary (Continued) 



TYPE 


MNEMONIC 


OPERAND(S) 


BYTES 


STATUS 


9440 


OPERATION PERFORMED 


C 


MEMORY 

OPERATE AND 

SKIP-ON- 

CONOmON 


ISZ 
DSZ 


(")DISP(,IX) 
(")DISP(,IX) 


2 
2 




X 
X 


[EA]-[EA] + 1 

If [EA] =Othen [PC]-[PC]+1 

Increment memory contents and skip if zero. 
(EA]-[EA]-1 
If [EA] =Othen [PC] — [PC]+1 

Decrement memory contents and skip If zero. 


K 
K 

Z 


INTEN 
INTDS 
INTA(f) 

MSKO(f) 
TRAP 
SKP(t) 


AC 
AC 

CPU 


2 
2 
2 

2 
2 




X 
X 
X 

X 
X 


[IONl-1 

Enable interrupts. Same as NIGS CPU. 
[ION] —0 

Disable Interrupts. Same as NIOC CPU. 
[AC] <5,0> — DEV 
[ION]-f 

The 6-bit device code of the device closest to the CPU that is requesting an interrupt is loaded 

into the low six bits of the Accumulator. Set ION via I/O command. 
[PM]-[AC] 
[ION] -f 

Move contents of Accumulator to Priority Mask. Set ION via I/O command. 
[26J-[PC] 
[PC]-[27„] 

Performs a software interrupt. 
If t is true, [PC] — [pel +1 

If interrupt or power fail condition satisfied, skip next instruction. 




HALT(f) 




2 




X 


[ION] —f 
Set ION via I/O command, then halt. 



Table 4-3. MicroNova and 9440 Instruction Set Object Codes 



INSTRUCTION 


OBJECT CODE 


BYTES 


CLOCK 
PERIODS 


9440 


ADaCS#) 


S,0(.SKCND) 


1 ssdd 1 0Orrccnwww 


2 


5/7 


X 


ADD(CS#) 


S,D(,SKCND) 




2 


5/7 


X 


AND(CS#) 


S,D(,SKCND) 


Issddlllrrccnwww 


2 


5/7 


X 


COM(CS#) 


S,D(,SKCND) 


1 ssddOOOrrccnwww 


2 


5/7 


X 


DIAf 


ACDEV 


011aa001ffpppppp 


2 


15 


X 


DIBf 


ACDEV 


01 1aa01 Iffpppppp 


2 


15 


X 


DICf 


ACDEV 


011aa101ffpppppp 


2 


15 


X 


DIV 




7641 


2 


123 




DOM 


ACDEV 


OllaaOIOffpppppp 


2 


10 


X 


DOBf 


ACDEV 


OllaalOOffpppppp 


2 


10 


X 


DOCf 


ACDEV 


OllaallOffpppppp 


2 


10 


X 


DSZ 


{";)DISP(,IX) 


OOOIIixxbbbbbbbb 


2 


8/10* 


X 


HALTf 




011aa110ff111111 


2 


10 


X 


INCICS #) 


S.D(.SKCND) 


1 ssdd0 1 1 rrccn www 


2 


5/7 


X 


INTAf 


AC 


011aa011ff111111 


2 


15 


X 


INTDS 




60BF 


2 


10 


X 


INTEN 




607F 


2 


10 


X 


lORST 




011aa010ff111111 


2 


10 


X 


ISZ 


(";)DisP(,ix) 


OOOIOixxbbbbbbbb 


2 


8/10» 


X 


JMP 


(";)DISP(.IX) 


OOOOaxxbbbbbbbb 


2 


6/8* 


X 


JSR 


{";)DisP(,ix) 


00001 ixxbbbbbbbb 


2 


7/9* 


X 


LDA 


AC(";),DISP(.IX) 


01 laaixxbbbbbbbb 


2 , 


6/8* 


X 


MFFP 


AC 


OllaaOOOIOOOOOOl 


2 


8 




MFSP 


AC 


OllaaOIOIOOOOOOl 


2 


7 




Movicsm 


S,D (.SKCND) 


1 ssdd0 1 0rrccnwww 


2 


5/7 


X 


MSKOf 


AC 


OllaalOOff 111111 


2 


10 


X 


MTFP 


AC 


OllaaOOOOOOOOOOl 


2 


6 




MTSP 


AC 


OllaaOIOOOOOOOOl 


2 


6 




MUL 




76C1 


2 


86 




NEG(CS ft) 


S,D (.SKCND) 


1 ssddO0 1 rrccnwww 


2 


5/7 


X 


NIOf 


DEV 


OllOOOOOffpppppp 


2 


10 


X 


POPA 


AC 


01 laaOl 110000001 


2 


7 




PSHA 


AC 


01 laaOl 100000001 


2 


7 




RET 




6581 


2 


15 




RTCDSf 




01101010ff111111 


2 


10 


X 


RTCENf 




01110010ff111111 


2 


10 


X 


SAV 




6501 


2 


16 




SKPt 




OllOOIIIttpppppp 


2 


15/17 


X 


SKPT 


DEV 


oiioonittiiiiii 


2 


15/17 


X 


STA 


CPU 


OlOaaixxbbbbbbbb 


2 


6/8* 


X 


SUB(CS#) 


AC(")DISP(,IX) 


1 ssdd 1 1 rrccnwww 


2 


5/7 


X 


TRAP 


S,D (.SKCND) 


IssddqqqqqqqIOOO 


2 


9 





'Direct addressing. For indirect addressing, add two clock periods for each level of indirection. For auto- 
increment or auto- decrement locations, add three clock periods, plus two for each level of indirection. 



The following symbols are used in Table 4-3: 

aa Two bits selecting an Accumulator 

bbbbbbbb 8-bit signed two's complement address displacement 

cc Two bits selecting the carry option 

dd Two bits selecting the destination Accumulator 

ff Two bits selecting the I/O command 

i One bit selecting indirect addressing 

n One bit choosing the no load option 

pppppp Six-bit device number 

rr Two bits determining the shift option 

ss Two bits choosing the source Accumulator 
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tt Two bits choosing the I/O test 

www Three bits selecting the skip-on-condition option 

XX Two bits selecting the index option 

Execution times shown are for MicroNova. Where two execution times are shown (for example, 5/7), the second is the 
instruction time if the skip or branch is taken. See Table 4-4 for 9440 execution times. 

Table 4-4 shows the sequences of machine cycles by which the 9440 executes instructions, interrupt and 
data channel requests, and commands received via lines C3 - CO. 
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Table 4-4. 9440 Instruction Execution 










INSTRUCTION 
OR 
NO. OPERATION 


CYC'u E TYPE AND SEQUENCE" 


EXECUTION 

TIME* 

(ms) 


FETCH 


READ 


WRITE 


LDMAR 


I/O OUT 


I/O IN 


WAIT 


DCH 


1 Jump 


1 
















1.5 


2 Jump Indirect 


3 


1 


2 












4.5 


3 Jump to Subroutine 


1 
















1.5 


4 JSR Indirect 


3 


1 


2 












4.5 


5 Increment and Skip if Zero 


3 


1 


2 












4.5 


6 ISZ Indirect 


5 


1.3 


2.4 












7.5 


7 Decrement and Skip if Zero 


3 


1 


2 












4.5 


8 DSZ Indirect 


5 


1.3 


2,4 












7.5 


9 Load Accumulator 


2 


1 














3.0 


10 LDA Indirect 


4 


1.3 


2 












6.0 


1 1 Store Accumulator 


3 


1 


2 












4.5 


12 STA Indirect 


5 


1.3 


2,4 












7.5 


13 Complement 


















1.5 


14 Negate 








,;.#* 










1.5 


15 Move 


















1.5 


16 Increment 


















1.5 


1 7 Add Complement 


















1.5 


18 Subtract 


















1.5 


19 Add 


















1.5 


20 AND 


















1.5 


21 ALU with Skip 


1.2 
















3.0 


22 I/O Data In 


2 










1 






2.5 


23 1 O Data Out 


2 








1 








2.5 


24 Skip on Busy or Done 


2 










1 






2.5 


25 Interrupt 


5 


3 


2.4 


1 










7.5 


26 Data Channel 
















1 


1.0 


27 Wait 














1 




1.0 


28 Examine Accumulator 










2 








2.0 


29 Deposit Accumulator 










2 








2.0 


30 Load PC 




2 














2.5 


31 Examine Memory 




2 














2.5 


32 Examine Next 




2 














2.5 


33 Deposit Memory 






3 


2 










4.0 


34 Deposit Next 






3 


2 










4.0 


35 Continue 


2 
















2.5 



*For 9440 System using **e.g., No. 6, ISZ 

a 10 MHz oscillator. 1st cycle - 

Reprinted by permission of Fairchild Camera and 



Indirect: 2nd cycle — WRITE 
-READ 3rd cycle — READ 

Instrument Corporation. 
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4th cycle 
5th cycle- 



WRITE 
FETCH 



SYN 
M2 



^O 



O +5V 

(» 



MBUSY 



-<=>-> 



00 



01 
00 



PRE 

D Q 

LS74 

CK 




o 



o 



^ IBO - IB/ 

< > 



< > 



IB1 - IB7 



^ 



^ 
=> 



CK 



LS377 



N7^ 



LS377 



A1 -A7 



C> 



A8 -A15 



Memory 
Address 
Bus 



^ 



IBS - 181 5 



DIR G 

A B 

LS245 



DIR G 

A B 

LS245 



MDO - MD7 



C 



MD8-MD15 



(^ 



n 
d 



Memory 
Data Bus 



^ 



MD10-MD15 



^ 



N7^ 

CK 



LS378 



T7- 



LS378 



IR4 - IR9 



^ 



< •> 



IBS- IB15 



< > 



Instruction 
Register 
(12 bits) 



C> 



I/O 
Address 



DIR G 

A B 

LS245 



C 



DIR G 

A B 

LS245 



-==0 

DSC - DS5 ^"® 

>1 



DATAG - DATA7 



I/O Data 
Bus 



^ DATA8-DATA15 ^ 



Figure 4-18. 9440 Information Bus Dennultipiexing Logic 
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9440 - NOVA BUS INTERFACE 

We will now examine logic which expands the 9440 pins and signals to the standard Nova I/O bus and to a typi- 
cal microcomputer memory bus. Table 4-1 identifies the Nova I/O bus that is created. 

We will also illustrate that part of I/O device interface logic which is common to any I/O device — that is, logic 
associated with Busy, Done and Interrupt flags. 

Our discussion of logic needed to create a memory bus is quite general, reflecting the fact that there is no standard 
Nova memory bus. We will therefore limit ourselves to demonstrating, in general, how typical memory bus signals may 
be created from 9440 signals. But we will be specific in describing logic that expands the 9440 interface to a standard 
Nova I/O bus. 

The 9440-Nova bus interface description is divided into three parts: 

1) Expansion of the Information Bus into various Address and Data Busses required by the I/O and memory 
references. 

2) Creation of I/O interface control signals. 

3) Creation of memory interface control signals. 

We will examine each of the three logic expansions in turn. 

9440 INFORMATION BUS EXPANSION 

These four busses must be created out of the bidirectional 16-bit Information Bus: 

1) A bidirectional, 16-bit Memory Data Bus. 

2) An output only, 15-bit Memory Address Bus. 

3) A bidirectional, 16-bit I/O Data Bus. 

4) An output only, 6-bit I/O Device Address Bus. 

We must also latch I/O instruction object codes into a buffer out of which I/O instruction code bits can be read by I/O 
control signal logic. 

The 9440 Information Bus is low true; this means a low signal level represents a binary 1, while a high signal 
level represents a binary 0. Standard Nova I/O Data and Address Busses are also low true; we therefore do not 
need to invert signals during multiplexing and demultiplexing. 

There are many ways in which the 9440 Information Bus may be multiplexed to create the four required busses. 
We illustrate one possibility In Figure 4-18. This logic uses LS245 8-bit bidirectional tristate buffers to generate the 
two bidirectional Data Busses, while 8-bit and 6-bit gated, edge-triggered flip-flops create the Address Busses and the 
Instruction Object Code register. 

The Data Bus buffers each have a gate (output enable) input and a data direction input. The gate inputs are low true. 
Logic shown in Figure 4-18 selects the LS245 buffers while valid memory data or valid I/O data can exist. Within 
these select periods a data direction control signal is created to ensure that data flows in the correct direction. 



For the Memory Data Bus , MDO - MD15, the LS245 buffers must be selected either during a read or a write operation, 
as identified by MO or Ml. But these two sign als span addr esses and data occurring on the Information Bus. Valid data 
exists on the Information Bus when MBUSY is high while SYN is low: 



SYN 



MBUSY 



A 



5 



w- w ""^ ^ r i Te'iy^x t 



t 



during memory read cycles, 
CPU drives address here 
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This timing is also illustrated in Figur es 4-12 and 4-13. The logic of Figure '4-1 8 uses an LS74 flip-flop clocked by 
the low-to-high transition of MBUSY. This en sures that data is not driven in the tinne shaded in the preceding illustra- 
tion — between the high-to-low transition of SYN and the high-to-low transition of MBUSY. 

MO is used as the Mennory Data Bus data direction control. 

The I/O Data Bus buffer logic is somewhat simpler. The Information Bus is dedicated to transferring I/O data for the en- 
tire duration of a data input or data output machine cycle, as defined by 01 high and OO low; these two signals are 
therefore used to create gate (output enable) logic. The direction of the I/O data transfer is taken from IR7; this bit of the 
I/O instruction object code defines the direction of an I/O data transfer, as illustrated in Figure 4-18. 

For the Address Busses we do not use buffers; rather, we use gated-clock, edge-triggered flip-flops. This allows the ad- 
dress being output to be held stable on the Memory Address Bus, or the I/O Address Bus, after it is no longer on the In- 
formation Bus. 

In the case of the Memory Address Bus, the gate inputs are tied to M2, whic h will be low whenever a memory address 
is being output on the Information Bus. The high-to-low transition of SYN is intended to act as a memory address 
strobe; therefore it is inverted to clock the Memory Address Bus flip-flops when M2 is low. Observe that there are only 
fifteen lines on the Memory Address Bus; the high-order bit of a 16-bit memory address is reserved to indicated an in- 
direct address. Note also that the LS377 outputs are not tristate; therefore the Memory Address Bus will always hold 
the address of the most recently accessed memory location. 

Two LS378 6-bit gated-clock flip-flops are used to latch the lower 12 bits of instruction object codes off the Memory 
Data Bus, c_reatin3 the I/O Address Bus and the Instruction register. The six low-order output lines provide the I/O Ad- 
dress Bus, SO - S5. As you can see in Figure 1 9-8, only the low-order 11 bits of the I/O instruction need to be decoded 
by I/O logic; therefore we use the 16-pin LS378 parts, rather than the 20-pin LS377s which we used for the Memory 
Address Bus. Like the Memory Address Bus, the Instruction register and I/O Address Bus will al ways hold the most re- 
cently latched data. The Instruction register flip-flops are clocked by the low-to-high transition of MBUSY whenever an 
instruction object code is on the Memory Data Bus. This condition is guaranteed by logic which enables the clock only 
when 01 and 00 are both low, signifying an Instruction Fetch machine cycle. If we wished to latch only I/O instruc- 
tions, we could change the gate logic as follows: 



MDO 

MD1 

MD2 

OO 

01 



S-> 



to G of each LS378 



Latching the instruction object code only when its upper three bits are 01 1 (MDO high, MD1 and MD2 low) means that 
the Instruction register will only hold I/O instructions. Latching all instructions is sufficient, since an I/O execution 
machine cycle (01 high and 00 low) follows the fetch of an I/O instruction. Our logic will use lines 01 and OO to indi- 
cate execution of an I/O instruction. 

Let us now examine I/O bus control signal logic. 
9440-NOVA I/O BUS INTERRUPT SIGNALS 



Three signals on the standard Nova I/O bus are used by interrupt logic: INTR, INTA and INTP. 



INTR is the standard interrupt request signal. This signal can be tied directly to the 9440 INT REQ input. 

The interrupt acknowledge signal INTA is created in response to execution of the interrupt acknowledge instruction. 
We will describe logic which creates INTA along with other I/O bus control signals when we discuss Figure 4-19. 

INTP is the initial input to the highest priority device in an interrupt daisy chain. This may be illustrated as follows: 
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INTP may be connected to the complement of the 9440 output INT ON, in which case priorities within a daisy chain will 
not b e resolved while interrupts are disabled. Frequently the initial PIN input to a daisy chain will be tied to ground and 
INTP will not be used. Now interrupt priorities will be arbitrated whether or not interrupts have been enabled. 

As you will see, it takes very little logic to expand the 9440 interrupt signals to standard Nova I/O bus interrupt lines. 
But a considerable amount of interrupt-related logic must be present at external device controllers — logic which we 
will describe later in this chapter. 

9440-NOVA DMA CONTROL SIGNALS 



The only DMA logic provided by the 9440 consists of a DMA request signal, DCH REQ. When input low, this signal 
causes the 9440 to complete the instruction currently being executed, then to disable interrupts and wait. The DMA re- 
quest is acknowledged by outputting 01 low and OO high. 

All logic which actually implements any DMA transfer must be implemented external to the 9440. We will discuss 
briefly what logic would be required. 

The Request Enable line, RQENB, goes true to permit both interrupt and DMA requests. Central DMA control logic 
would contain an Enable flip-flop, analogous to the C PU's Interrupt Enable flip-flop. The output of this flip-flop, ANDed 
with INT ON from the 9440, would provide RQENB as follows: 



DMA enable 
INT ON 



o 



The DMA request line DC HR ma y be connected to the 9440 DCH REQ input. Thus requests will be accepted and 
granted by the 9440 CPU. DCHA, the acknowledgment signal, is simply decoded from lines 01 and 00: 



01 
00 



O 



DCHP is a priority line just like INTP. DMA daisy chain priorities would be implemented similarly to interrupt priorities. 

The 9440 surrenders control of the System Bus when it acknowledges a DMA request; therefore external logic must 
perform all signal manipulations and data transfers. DCHI and DCHO, which indicate the direction of data transfer, are 
signals output by external DMA control logic. 

The DMA control logic will input DCHMO and DCHM1 from the device requesting memory access. Of the four encoded 
modes shown in Table 4-1, "Data Out" and "Data In" can be handled with relative ease, especially if you use an LSI 
chip designed for DMA control. Implementing the other two functions, "Increment Memory" and "Add to Memory", re- 
quires much more logic since some arithmetic is required. Indeed, a one-chip microcomputer might supply this logic. 

Since OVFLO is true when an "Increment Memory" or an "Add to Memory" operation produces a result greater than 
FFFFiQ. this signal would be produced by the logic which performs those operations. 

Figure 4-19 shows 3-to-8 and 2-to-4 decoders creating Ndva I/O Bus control signals. The signal logic directly 
interprets I/O instruction object code bits illustrated in Figures 4-8, 4-9, and 4-10. Note that the Instruction 
register bits from Figure 4-18 are low t rue, and that Instruction register lines are numbered according to Nova conven- 
tion, where the low-order line is IR15. 
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Figure 4-19. Creation of Nova I/O Bus Control Signals from 9440 Signals 
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Instruction object code bits are continuously read out of the Instruction register (lrt4 - IR15), but I/O control sig- 
nals are created only during an I/O Execute machine cycle (when 01 is high and 00 is low). 

The logic of Figure 4-19 may be divided into these four sections: 

1) Creation of simple data transfer control signals 

2) Creation of I/O skip logic. 

3) Creation of interrupt control signals. 

4) Creation of control signals STRT, CLR and lOPLS. 

Let us first consider simple data transfer control signals. There are six signals: DATIA. DATIB, DATIC, DATOA, 
DATOB. and DATOC. These are created by the LS138 3-to-8 decoder in Figure 4-19, and enabled when the I/O 
device address is other than SFig. 

If you look at Figure 4-8 you will see that instruction bits 10 and 9 (IR5 and IR6) select one of the three registers that 
nnay exist at an I/O device, while bit 8 (IR7) differentiates between I/O data input and I/O data output. These three bits 
are input to the LSI 38 decoder so that the six data transfer signals and the Skip signal are decoded at the outputs. The 
decoder is enabled only during an I/O Execute machine cycle — that is, when 01 is high and 00 is low. However, if the 
I/O device address is 3F-|6. then CPU OP will be true and no data transfer signal will go true. It is not strictly necessary 
to disable the signals with CPU OP; since none of the I/O devices will be assigned the address 3Fi q. none of them will 
respond to I/O instructions with that address. 

The Skip con trol. SKP, output from the LS138 decoder, is used to e nable SELB and SELD onto Information Bus 
lines IBO and IBI.This is don e usin g thr ee-sta te buffers enabled by SKP low; the buffers in Figure 4-19 might be part 
of an LSI 25 or an LS367 chip. SELB and SELD are inputs to the buffers, while the outputs are connected to Information 
Bus lines IBOa nd IB1 . W e assu me that as soon as any I/O device is s electe d, it imme diately connects its Busy and Done 
statuses_to the SELB and SELD control lines of the I/O bus. However. SELB and SELD will not appear on Information Bus 
lines IBO and IB1 unless a Skip I/O instruction has been executed. 

When an I/O instruction is executed specifying device 3Fig, a set of interrupt-related I/O instructions is executed, 
as illustrated in Figure 4-10. Most of the instructions illustrated in this figure specify events internal to the CPU. For 
example, "enable interrupts" and "disable interrupts" apfsly to CPU interrupt logic; moreover, the Skip instructions in- 
terrogate interrupt request status and power fail status within the CPU. "Acknowledge Interrupt" (INTA), "Output 
Interrupt Mask" (MSKO) and "Clear All I/O Devices" (lORST) are the only instructions which require control 
signals to be generated on the I/O bus. These control signals are generate d by qua lifying the decoder of the in- 
struction bits with a devi ce 3F i6 selec t cod e. The device 3Fi6 select code, CPU OP, is created by ANDing the low- 
order six instruction b its (IR10 through. IR1 5). Thus the gates producing INTA, MSKO. and lORST are effectively 
switched on and off by CPU OP Note t hat lOR ST is generated either by execution of a "Clear I/O Devices" instruction, 
or by the master system Reset signal. RESET. 

Let us next consider logic needed to create STRT, CLR, and lOPLS. 

These control signals should b e act ivated after the appropriate I/O transfer has take n pla c e. Th us thejogic in Figure 
4-19 provides a gating signal. PLS. which goes low on the low-to-high transition of SYN. PLS is theQ output of the 
LS74 flip-flop in Figure 4-19. The timing for STRT. CLR. or. lOPLS results as follows: 



§yF3 



lOPLS. STRT, 
or CLR 



Instruction Fetch 



-I/O Execute 




Instruction Fetch 



CPU or I/O Device reads 
data here- 



4-51 



The LSI 39 2-to-4 decoder decodes instruction object code bits 7 and 6 (iR5 and IrS), providing that the I/O instruction 
being executed is not an I/O Skip instruction. (The other half of the LSI 39 chip could be used to decode lines 01 and 
OO, instead of the gating logic shown in Figures 4-18 and 4-19.) 
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Figure 4-20. Busy, Done, and Interrupt Status Logic Required by I/O Device Controllers on the Nova I/O Bus 

NOVA I/O DEVICE CONTROLLER LOGIC 

Interface logic which an external device needs in order to connect to the standard Nova I/O bus depends on the 
nature of the external device. A minicomputer device controller may be very complex, even costing more than 
the minicomputer itself; that is because minicomputer devices that connect to the I/O bus are peripherals, such 
as printers, disks, etc. When we reduce the Nova to microprocessor terms, however, external devices con- 
nected to the I/O bus reduce to such primitive elements as parallel I/O ports or serial data lines. Within this 
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reduced context we can synthesize the minimum necessary elements of an I/O interface as consisting of three 
status flags: Busy, Done, and an Interrupt request. We can implement these three status flags using three LS74 
flip-flops, as illustrated in Figure 4-20. Device select logic in this figure is limited to showing a select signal 
which will be generated true when the appropriate device code appears on the I/O device Address Bus. We 
have discussed I/O device select logic at various points earlier in this chapter. 

Let us look at the BUSY and the DONE status logic. These are the operations which may affect the condition of the 
BUSY and DONE statuses: 

1) At the star t of an I/O operation BUSY must be set while DONE is clear. This condition is identified by 01 in bits 7 
and 6 (IRS and TrS) of the I/O instruction object code, which generates the STRT control signal of the 1/0 bus. 

2) At the completion of an operation BUSY is cleared and DONE is set. This change in status setting must be imple- 
mented automatically by I/O device interface logic; it alone knows when the I/O operation has been completed. 

3) BUSY and DONE may be cleared by the CPU. This is specified by 10 in bits 7 and 6 (IRS andlR9) of the I/O instruc- 
tion, which generates the CLR control signal on the I/O bus. 

4) There is a "Clear All I/O Devices" instruction. This instruction generates lORST on the I/O bus; it clears BUSY and 
DONE statuses at all I/O devices. 

5) A Master Reset must also clear the BUSY and DONE statuses. This Master Reset signal can also create lORST, as il- 
lustrated in Figure 4-19. 

Two D-type flip-flops implement the BUSY and DONE status logic. These two D-type flip-flops are clocked by an 
"I/O Complete" signal which local devi ce lo gic must ge nerate. The BUSY and DONE statuses are generated by the flip- 
flop Q outputs which must connect to SELB and SELD, as required by I/O skip logic, which we have already described. 

The BUSY flip-flop uses its Set and Clear logic to control the BUSY status. The BUSY status is set by STRT and SELECT 
both true. This combination of STRT and SELECT sets the device BUSY status while it resets the DONE status. 



lORST 



CLR 



STRT 



Either CLR and SELECT both true or iORST true will activate the Clear input of the BUSY flip-flop. 
Neither of these conditions will be present when BUSY is set by the STRT pulse. Subsequently, 
when STRT or SELECT goes false, BUSY will stay true until it is reset by "I/O Complete" or by an 
active Clear input, which will occur when either IORST or both CLR and SELECT are true. 

The DONE status is set by the "I/O Complete" pulse after BUSY has been set. Once DONE is set, it will remain true until 
the flip-flop is cleared. These conditions are provided by OR logic at the D input to the DONE flip-flop. The Clear input is 
activated by any one of the following conditions being true: 

1) STRT and SELECT both true; thus the DONE status is reset at the same time as the BUSY status is set. 

2) The master Reset, IORST. 

3) CLR and SELECT both true. 



The device interrupt may be individually disabled by a Mask Out instruction's execution; this creates the MSKO control 
signal used to permit the clocking of the interrupt mask flip-flops. Accompanying execution of the Mask Out instruc- 
tion, a 16-bit data value is output on the I/O D ata Bus. An I/O De vice's in terrupt logic is controlled by one bit of this 
mask, the bit transmitted via I/O Dat a Bus line DATAn. Therefore DATAn becomes the D input to the interrupt mask 
flip-flop. A 1 in the mask bit (DATAn low) disables interrupts from the I/O device. In Figure 4-20, the out put of the 
flip-flop becomes the interrupt enable signal, INT ENABLE, which gates the device's interrupt request onto INTR. 

The bottom flip-flop in Figure 4-20 implements interrupt logic for the I/O interface. Let us summarize the con- 
ditions that can affect I/O interface interrupt logic. Providing interrupts are enabled at the I/O interface, an interrupt 
will be reque sted whenever an I/O operation is completed, as identified by the DONE status going true. If INT ENABLE 
is true, INTR will go low as soon as the DONE status is set. 

Interrupt logic may be enabled by a master I/O reset; therefore IORST is connected to the flip-flop Preset input. 

9440 MEMORY BUS 

There being no standard Nova Memory Bus, we will look at the signals available to you when you interface 
memory to the 9440. 

First return to Figure 4-18. This figure shows how stable Data and Memory Busses may be demultiplexed off 
the 9440 Information Bus. In order to create a Memory Bus of any type, all you need is control signals to accom- 
pany the Memory Data Bus and the Memory Address Bus. 

Figure 4-21 presents an example of memory control signals derived from 9440 signals, and Figure 4-22 
shows the timing for these signals. The four D-type flip-flops of an SI 75 chip, along with some combinatorial logic, 
constitute a state machine to generate signals required by memory and the 9440 CPU. The four flip-flops are triggered 
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by MEMORY CLOCK. In order that all worst-case delay times be satisfied, the frequency of MEMORY CLOCK should not 
exceed 23.8 MHz; if LS parts are used, the maxinnum worst-case MEMORY CLOCK frequency is 10.8 MHz. The com- 
mon clear of the four flip-flops will be activated if none of the lines MO, Ml, or M2 is true. 
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Figure 4-21. Memory Controls Derived from 9440 Signals Using State Machine Logic 



4-54 




Figure 4-22. Timing for 9440-Based Memory Controls 

Provided that either Ml, Ml or MU is low (sign ifying a memory access maciiine cycle) the MEM ENABLE signals 
will go true on the first MEMORY CLOCK after SYN goes low. MEM ENABLE will stay on until the first MEMO- 
RY CLOCK after SYN goes high again. 



On the rising edge of MEMORY CLOCK after MEM ENABLE goes on, MBUSY and ADDRESS VALID will go true. 



Memory control logic must return MBUSY to the CPU, since the 9440 requires interaction of the MBUSY and SYN sig- 
nals in order to complete memory access cycles. We discussed this e arlier in this chapter, in the text accompanying 
Figures 4-12 and 4-13. A more complex memory interface could use MBUSY to lock out CPU memory accesses while 
the memory is busy — for example, while memory is responding to a direct memory access. 

The memory logic itself may require some signal to be true as long as a valid address is on the Memory Address Bus. 
Thus, our logic provides the signal ADDRESS VALID, which goes on after the contents of the Memory Address register 
(shown in Figure 4-18) have had time to settle, and remains until t he en d of the memory cycle. In Figure 4-18, the 
Memory Address register is clocked by the high-to-low transition of SYN, but a system might use the leading edge of 
ADDRESS VALID to clock the Memory Address register. 

On the MEMORY CLOCK after MBUSY goes on, the ENABLE flip-flop clocks on. If MS or Ml is low at this time, 
then READ or WRITE will go on and stay on until the MEMORY CLOCK after MEM ENABLE goes off. The signals 
READ and WRITE tell the memory chips the direction of the data transfer. 

Of course, different system signal and timing specifications would require different implementations of memory sig- 
nals. A memory system might use one-shots or delay lines to create pulsed signals, and simple combinatorial logic for 
signal levels. A state machine implementation could use a Counter or Shift register, or perhaps a field-programmable 
logic sequencer such as the Signetics 82S105. 
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DATA SHEETS 

This section contains specific electrical and timing data for the following devices: 

• MicroNova 
. 9440 
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MICRONOVA 



1- ABSOLUTE MAXIMUM RATINGS*— | 


Supply Voltage Range V3Q 


-2 to 


-7 Volts 


Supply Voltage Range Vqq 


-0.3 to 


+ 7 Volts 


Supply Voltage Range Vq^) 


-0.3 to 


+ 13 Volts 


Supply Voltage Range Vqq 


-0.3 to 


+ 17 Volts 


Input Voltage Range Vj 


-0.3 to 


+ 7 Volts 


Input Current Range Ij 


to 


6 mAmps 


Operating Temperature Range T^ 


to 


+ 70 °C 


Storage Temperature Range Tg^ 


-55 to 


+ 125°C 


Average Power Dissipation 


- 


1 Watt 



NOTES All voltages in this document are 
referenced to Vgg (ground), 

*Subjecting a circuit to conditions either 
outside these limits or at these limits for an 
extended period of time may cause irreparable 
damage to the circuit. As such, these ratings 
are not intended to be used during the 
operation of the circuit. Operating 
specifications are given in the DC (STATIC) 
CHARACTERISTICS TABLE. 



Data sheets on pages 4-D2 through 4-D3 reprinted by permission of Data General Corporation. 
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MICRONOVA 



D. C. (STATIC) CHARACTERISTICS 
mN601 

OPERATING SPECIFICATIONS 



Tj^ range to 70 °C \qq = 14 : 1.0 Volts I^c = 20 m Amps Average Ibb 

Vj;q 5 1 0.25 Volts Vgg = -4.25 1 .25 Volts Idd = 50 mAmps Average Isg 

Vdd = 10 1 1.0 Volts Vgs =0-0.0 Volts Iqg " 20 m Amps Average 



-. 1 mAmps Average 
-150 mAmps Average 



CHARACTERISTIC 


SYMBOL 


UNITS 


PINS 


LIMITS 


MIN, MAX, 


INPUT LOW VOLTAGE 


ViL 


Volts 


al,3 and a2,4 


-2,0 


♦ 0.5 


MB 0-15 , CLAMP 
EXTINT. DCH INT 


-1,0 


♦ 1.0. 


I CLOCK, I ODATA 1, 
1 O DATA 2 


-1.0 


♦ 0.5 


INPin' CURRENT FOR 
LOW STATE 


'IL 


mAmps 


al,3and a2,4 




♦ .01 


MB 0-15 





-2.0 


EXTlN-t, Kk M. CLAMP 


-2.0 


-4.0 


I O CLOCK. I O DATA I, 
I O DATA 2 


-2.0 


-4.0 


INPUT HIGH VOLTAGE 


VlH 


Volts 


al,3 aiidti2,4 


♦ 13.0 


♦ 15.0 


MB 0-15 , crsOT 
EXTINT, ccrnuT 


*4,25 


♦ 5.8 


I CLOCK, I O DATA I, 
I O DATA 2 


+ 2,5 


♦ 5,8 


INPUT CURRENT FOR 
HIGH STATE 


'IH 


mAmps 


al,3 and Ii2,4 




-.01 


MB 0-15 




-.06 


I CLOCK, I O DATA 1, 1 O DATA 2 




-1.0 






-.02 


CIaMP 




♦ .001 


OUTPUT LOW VOLTAGE 


Vol 


Volts 


HALT 




♦ 3.0 


■MB 0-15 , 

1 INPUT, PAUSE, 

SAEG. WEG. PG 




♦ 0.4 


I/O CLOCK, I/O DATA I, I/O DATA 2 




♦ 0.5 


OUTPUT CURRENT FOR 
LOW STATE 


'OL 


luAmps 


PG. I O INPUT 


♦ 4,0 




MB 0-15 . 1 O CLOCK 
I DATA I , . O DATA 2 
PAUSt, SAEG, PG, HALT 


♦ 2,0 




OUTPUT HIGH VOLTAGE 


^OH 


Volt.s 


MB 0-15 

I CLOCK, I DATA 1, I O DATA 2 

I INPUT, PAUSE, 

SAEG. WEG, PG 


♦ 4.25 




HALT 


vcc-o.i. 




OUTPUT CURRENT FOR 
HIGH STATE 


lOH 


niAmps 


HALT. 




-.01 


MB 0-15 


- 


-.06 


I INPUT , PC 




-.02 


I CLOCK, I DATA I, I O DATA 2, 
PAUSE SAEG, WEG 


- 


-.01 


INPUT CAPACITANCE 


Cl 


PF 


iil,3 and •2,4 




100 


tLAMP 

MB 0-15 , I CLOCK 
I DATA I, I ODATA 2 
EXTINt, DCH INT 




10 



NOTE 

Logic "1" is defined as the more positive voltage as are the maximum 
figures given under voltage limits. Logic "0" is defined as the more 
negative voltage as are the minimum figures given under voltage limits. 



1 the conventional ! 



is defined as flowing into 



Positive current, 
the pin. 

On power-up, Vqq must be within its specified operating range (with 
respect to ¥35) before any of the other power supply voltages are ap- 
plied to the circuit. 



4-D3 



9440 



ABSOLUTE MAXIMUM RATINGS (beyond which the useful life of the device may be impaired) 
Storage Temperature -65° to 15(yc 
Ambient Temperature Under Bias -55 to +125°C 
Vcc Pin Potential to Ground Pin -0.5 to +6.0 V 
Input Voltage (dc) -0.5 to +5.5 V 
Input Current (do) -20 to +5 mA 
Output Voltage (Output HIGH) -0.5 to +5.5 V 
Output Current (dc) (Output LOW) +20 mA 
Injector Cun-ent (I|nj) +500 mA 
Injector Voltage (V,nj) -0.5 to + 1 .5 V 

DC CHARACTERISTICS OVER OPERATING TEMPERATURE RANGE (O to 75° C) 

llNJ(min) = 300 mA, liNJ(max) = 400 mA, VcC(min) = 4.75 V, VcC(max) = 5.25 V 


SYMBOL 


CHARACTERISTIC 


LIMITS 


UNITS 


TEST CONDITIONS 


MIN 


TYP 


MAX 


VrH 


Input HIGH Voltage 


2.0 






V 


Guaranteed Input HIGH Voltage 


ViL 


Input LOW Voltage 






0.8 


V 


Guaranteed Input LOW Voltage 


VcD 


Input Clamp Diode Voltage 




-0.9 


-1.5 


V 


Vcc = 4.75 V, l|N = -18 mA 
llNj = 300 mA 


VOH 


Output HIGH Voltage 

RUN, CARRY, INT ON, SYN, CLK OUT, Oq, O, 


2.4 


3.4 




V 


Vcc = 4.75 V, loH = -400 ^^ 
I|l4j ^ 300 mA 


Output HIGH Voltage 
IBo - IBi5 


2.4 


3.4 




V 


Vcc = 4.75 V, loH = -1.0 mA 
llNj = 300 mA 


ICEX 


Output Leakage Mq, M^, Mj 






1.0 


mA 


Vcc = 4.75 V, VoH = 5.25 V 
l|Nj = 300 mA 


Vol 


Output LOW Voltage 




0.25 


0.5 


V 


Vcc = 4.75 V, loL = 8.0 mA 
l|Nj = 300 mA 


l|H 


Input HIGH Current 




1.0 


20 


mA 


Vcc = 5.25 V, V,N = 2.7 V 
l|Nj = 300 mA 


C0-C3, DCH REQ, INT REQ, MBSY, MR 


Input HIGH Current 
CP 




2.0 


40 


mA 


Vcc = 5.25 V, V|N = 2.7 V 
l|Nj = 300 mA 


Input HIGH Current 
IBo - IB15 (3-State) 




5.0 


100 


yA 


Vcc = 4.75 V, V,N = 2.7 V 
l|Nj = 300 mA 


Input HIGH Current 
All Inputs 






1.0 


mA 


Vcc = 4.75 V, V|N = 5.5 V 
llNj = 300 mA 


l|L 


Input LOW Current 
All inputs except CP 




-0.21 


-0.36 


mA 


Vcc = 5.25V, V|N = 0.4 V 
l,Nj = 300 mA 


Input LOW Current 
CP 




-0.42 


-0.72 


mA 


Vcc = 5.25 V, V,N =0.4V 
l|Nj = 300 mA 


'OZH 


OFF State (High^ Impedance) 
Output Current IBq - IB15 






100 


mA 


Vcc = 5.25 V, VouT = 2.4 V 
l||))j = 300 mA 


'OZL 


OFF State (High_lmpedance) 
Output Current IBq - IB^s 




-0.21 


-0.36 


mA 


Vcc = 5.25 V, VouT = 0.4 V 
l|Nj = 300 mA 


los 


Output Short Circuit Current 
All Outputs Except Mq, M^, M2 


-15 




-100 


mA 


Vcc = 5.25 V, VouT = 0.0 V 
l,Nj = 300 mA 


Ice 


Supply Current 




150 


200 


mA 


Vcc = 5-25 V 


V.NJ 


Injector Voltage 




1.0 




V 


l|Nj = 300 mA 





Data sheets on pages 4-D4 through 4-D10 reprinted by permission of Fairchild Camera and Instrument Corporation. 
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9440 



AC CHARACTERISTICS: Ta = to 75° C — Figures 8 & 9 | 


SYMBOL 


CHARACTERISTIC 


LIMITS-ns 


NOTE 


MIN 


TYP 


MAX 


tCPSYL 


Propagation Delay, CLOCK to SYN going LOW 




150 






tCPSYH 


Propagation Delay, CLOCK to SYN going HIGH 




160 






tMBSYL 


Propagation Delay, MBSY going HIGH to SYN going LOW 




70 






tMBW 


MBSY Min Pulse Width (HIGH) 




30 






tMBS 


Set-up Time, MBSY HIGH to CLOCK 




-40 






tMBHO 


Hold Time, MBSY HIGH after CLOCK 




60 






tCPMH 


Propagation Delay, CLOCK to M2, Mi, Mo going HIGH 




160 






tCPML 


Propagation Delay, CLOCK to M2, Mi, Mo going LOW 




170 






tCPOH 


Propagation Delay, CLOCK to O1, Co going HIGH 




160 




Fig. 9 Only 


tCPOL 


Propagation Delay, CLOCK to O1, Oo going LOW 




170 




Fig. 8 Only 


tCPAH 


Propagation Delay, CLOCK to ADDRESS IBo-15 going HIGH 




170 






tCPAL 


Propagation Delay, CLOCK to ADDRESS IBo-15 going LOW 




180 






tMBAF 


Propagation Delay, CLOCK to ADDRESS iBo-15 going 3-state 




110 






tDS 


Set-up Time, DATA IBo-15 to CLOCK 




-110 






tDHD 


Hold Time, DATA iBo-15 after CLOCK 




130 






tcs 


Set-up Time, C3, C2, Ci, Co to CLOCK 




-110 






tCHD 


Hold Time, C3, C2. Ci. Co after CLOCK 




130 






tCPRH 


Propagation Delay, CLOCK to RUN HIGH 




160 




Fig. 8 Only 


tCPRL 


Propagation Delay, CLOCK to RUN LOW 




170 




toes 


Set-up Time, DCH REQ to CLOCK 




-110 




tOCHD 


Hold Time, DCH REQ after CLOCK 




130 




tis 


Set-up Time, INT REQ to CLOCK 




-100 




tlHD 


Hold Time, INT REQ after CLOCK 




120 




tCPCYH 


Propagation Delay, CLOCK to CARRY HIGH 




160 




tCPCYL 


Propagation Delay, CLOCK to CARRY LOW 




150 




tCPIOH 


Propagation Delay, CLOCK to INT ON HIGH 




200 




tCPIOL 


Propagation Delay, CLOCK to INT ON LOW 




190 




NOTES: 

1. The Information Bus is driven as a result of the previous cycle. 

2. The Fetch and Read cycles will be stretched out for slower memories. 

3. Applies to console operation using this cycle type. 
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9440 




Fig. 8 Fetch Cycle 




RUN, DCH REQ, INT REQ, CARRY, INT ON 
unaffected during this cycle. 



Fig. 9 Read Cycle 
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AC CHARACTERISTICS: Ta = to 75°C — Figures 10 & 11 



SYMBOL 


CHARACTERISTIC 


LIMITS-ns 


NOTE 


MIN 


TYP 


MAX 


tCPSYL 


Propagation Delay, CLOCK to SYN going LOW 




150 






tCPSYH 


Propagation Delay, CLOCK to SYN going HIGH 




160 






tMBSYL 


Propagation Delay, MBSY going HIGH to SYN going LOW 




70 






tMBW 


MBSY Min Pulse Width (HIGH) 




30 






tMBS 


Set-up Time, MBSY LOW to CLOCK 




-40 






tMBHD 


Hold Time, MBSY LOW after CLOCK 




60 






tCPMH 


Propagation Delay, CLOCK to M2, Mi, Mo going HIGH 




160 






tCPML 


Propagation Delay, CLOCK to M2, Mi, Mo going LOW 




170 






tCPOH 


Propagation Delay, CLOCK to O1, Oo going HIGH 




160 






tCPOL 


Propagation Delay, CLOCK to O1, Oo going LOW 




170 






tCPDH 


, Propagation Delay, CLOCK to DATA IBo-15 going HIGH 




170 






tCPDL 


Propagation Delay, CLOCK to DATA IBo-is going LOW 




180 




Fig. 10 Only 


tCPDF 


Propagation Delay, CLOCK to DATA IBo-15 going 3-state 




110 






tCPAH 


Propagation Delay, CLOCK to ADDRESS IBo-15 going HIGH 




170 






tCPAL 


Propagation Delay, CLOCK to ADDRESS IBo-15 going LOW 




180 




Fig. 11 Only 


tCPAF 


Propagation Delay, CLOCK toADDRESS IBo-15 going 3-state 




160 






tcs 


Set-up Time, C3. C2, Ci, Co to CLOCK 




-110 






tCHD 


Hold Time, C3, C2, Ci, Co after CLOCK 




130 







NOTES; 

3. Applies to console operation using this cycle type. 

4. The Information B us is dr iven as a result of the p revious cycle. 

5. The 9440 waits for MBSY to go LOW. By holding MBSY HIGH, the user may idle the processor. 




RUN, DCH REQ, INT REQ, CARRY. INT ON 
unaffected during this cycle. 



Fig. 10 Write Cycle 



4-07 



9440 




- H IMBSYL M - (D 



-tCPML ^1 



IMBW-*^ V*- I -»• 



tMBHoH - 



ADDRESS OUT 



tCS ■♦-tCHO 



■<- tCPAF -^ 

zz3- 



RUN, DCH REQ, INT REO, CARRY, INT ON 
unaffected during thit cycle. 



Fig. 11 Load Memory Address Register Cycle 




3^ 



- tCPOH ^i 



> 



INT REO 
CARRY 



Fig. 12 I/O Out Cycle 
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AC CHARACTERISTICS: Ta = to TSOQ— Figures 12, 13, 14, 15 



SYMBOL 


CHARACTERISTIC 


LIMITS-ns 


NOTE 


MIN 


TYP 


MAX 


tCPSYL 


Propagation Delay, CLOCK to SYN going LOW 




150 






tCPSYH 


Propagation Delay, CLOCK to SYN going HIGH 




160 






tCPMH 


Propagation Delay, CLOCK to Ma, Mi, Mo going HIGH 




160 






tCPML 


Propagation Delay, CLOCK to M2, Mi, Mo going LOW 




170 






tCPOH 


Propagation Delay, CLOCK to O1, Oo going HIGH 




160 






tCPOL 


Propagation Delay, CLOCK to O1, Oo going LOW 




170 






tCPOH 


Propagation Delay, CLOCK to DATA IBo-is going HIGH 




170 






tCPDL 


Propagation Delay, CLOCK to DATA IBo-15 going LOW 




180 




Fig. 12 Only 


tCPDF 


Propagation Delay, CLOCK to DATA IBo-15 going 3-state 




110 






tDS 


Set-up Time, DATA IBo-is to CLOCK 




-110 




Fig. 13 Only 


tDHD 


Hold Time, DATA IBo-15 after CLOCK 




130 




tcs 


Set-up Time, C3, C2, Ci, Co to CLOCK 




-110 






tCHD 


Hold Time, C3, C2, Ci, Co after CLOCK 




130 




Fig. 14 Only 



NOTES; _ 

6. During DCH, the 9440 is not driving the M lines. An external device can control the memory when 

7. The 9440 floats the IBo-15. The Information Bus is available to the I/O devices and the memory as 



a LOW is applied to the appropriate M line, 
needed. 




-*A Ids "*-tDHD-»-| 
— ^ DATA IN )- 



DCH REO 



INT REO 
CARRY 
INT ON 



Fig. 13 I/O In Cycle 
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9440 




IBo-15 

Co-3 



Fig. 14 Walt Cycle 




<S) M2 



® IBo-is 



Co-3 
RUN 



INT REO 
CARRY 



Fig. 15 Data Channel Request Cycle 
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Chapter 5 
THE INTEL 8086 



The 8086 is Intel's first 16-bit microprocessor. It is significantly more powerful than any prior microprocessor. 

The 8086 assembly language instruction set is upward compatible with 8080A — but at the source program 
level only. That is to say, every 8080A assembly language instruction can be converted into one or more 8086 assem- 
bly language instructions. There is no reason why anyone would try to convert 8086 assembly language instructions, 
one at a time, into one or more 8080A assembly language instructions, but if you did, you would soon become 
hopelessly tangled in conflicting memory allocations and special translation rules. That is why we say that the 8086 
and 8080A assembly language instruction sets are "upward" compatible. 

The 8086 and 8080A assembly language instruction sets are not compatible at the object code level, which means that 
8080A programs stored in read-only memory are useless in an 8086 system. 

The 8085 and 8080A assembly language instruction sets are identical, with the exception of the 8085 RIM and SIM in- 
structions. The 8085 RIM and SIM instructions cannot be translated into 8086 instructions. This is because the RIM and 
SIM instructions use the serial I/O logic of the 8085, which has no 8086 counterpart. Without the RIM and SIM instruc- 
tions, the 8085 and 8080A assembly language instruction sets are identical; therefore the 8086 assembly language 
instruction set must also be upward compatible with the 8085 assembly language instruction set — apart from 
the RIM and SIM instructions. 

The 8085 and 8080A assembly language instruction sets are object code compatible — with the exception of the 8085 
RIM and SIM instructions. That is to say, a program existing in read-only memory could be used with one 
microprocessor or the other. 

The 8080A assembly language instruction set is a subset of the Z80 assembly language instruction set. That is to say, 
the Z80 will execute an 8080A object program — but the reverse is not true. The 8080A cannot execute Z80 programs 
when the full Z80 instruction set is used. The 8086 assembly language instruction set is not upward compatible 
with the Z80 assembly language instruction set. 

As a historical note, it is worth mentioning that the 8008 microprocessor, which preceded the 8080A, was also com- 
patible only at the source program level. That is to say, there is an 8080A assembly language instruction for every 8008 
assembly language instruction, but the two microprocessor object code sets are not the same. 

The various instruction set compatibilities that we have described may be illustrated as follows: 



(Excluding RIM and 
SIM instructions) 



' Source program of lower microprocessor 
can be assembled to generate upper 
microprocessor object program 

Lower microprocessor instruction set is a 
subset of upper microprocessor instruction 
set at the object program level 
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These are the most interesting innovations to be found in 8086 hardware design: 

1) 8086 Central Processing Unit logic has been divided into an Execution Unit (EU) and a Bus Interface Unit (BlU). 
These two halves operate asynchronously. The Bus Interface Unit handles all interfaces with the external bus; it 
generates external memory and I/O addresses and has a 6-byte instruction object code queue. Whenever the EU 
needs to access memory or an I/O device, it makes a bus access request to the Bus Interface Unit. Providing the 
Bus Interface Unit is not currently busy, it acknowledges the bus access request from the EU. When the Bus Inter- 
face Unit has no active pending bus access requests from the EU, it performs instruction fetch nnachine cycles to 
fill the 6-byte instruction object code queue. The CPU takes its instruction object codes from the front of the queue. 
Thus instruction fetch time is largely eliminated. 

2) The 8086 has been designed to work in a wide range of microcomputer system configurations, ranging from a sim- 
ple one-CPU system to a multiple-CPU network. To support this wide flexibility, a number of 8086 pins output 
alternate signals. This may be illustrated as follows: 



Minimum Configurations 



Maximum Configurations 



+ 5 V 



8086 



? - 

I MN/MX 



(^=C> 



These signals 
do not change 



T 



jy Simple control output 
N for use in one-CPU 



system 




> These signals 
do not change 



Complex control signals 
useful in multi-CPU 
networks 



3) 



4) 



5) 



6) 



The same pins output these two sets of signals, based on a level of MN/MX. This wholesale re-allocation of signals 
is a highly imaginative and innovative first for the microprocessor industry. 

The 8086 has built-in logic to handle bus access priorities in multi-CPU configurations. (This is not a new concept; 
National Semiconductor's SC/MP has had it for years.) 

In multi-CPU configurations, each 8086 CPU can have its own local memory, while simultaneously sharing com- 
mon memory. The common memory may be shared by all CPUs, or by selected CPUs. 

The 8086 has been designed to compete effectively in program intensive applications that have been the domain 
of the minicomputer. Up to a million bytes of external memory can be addressed directly. All memory addressing is 
base relative; this memory addressing technique naturally generates relocatable object programs. (Relocatable ob- 
ject programs can be moved from one memory address space to another and re-executed without modification.) 
Also, since the 8086 utilizes stack-relative addressing, re-entrant programs are easily written. (Re-entrant programs 
can be interrupted in mid-execution and re-executed. For example, a subroutine which calls itself is re-entrant; a 
program which can be interrupted in mid-execution by an external interrupt, and then re-executed within the in- 
terrupt service routine, is also re-entrant. 



The 8086 uses prefix instructions that modify the interpretation of the next instruction's object code. 

The 8086, liice its predecessor, the 8080A, is really one component of a multiple-chip microprocessor configura- 
tion. 

In addition to the 8086 microprocessor itself, you must have an 8284 Clock Generator/Driver. You cou Id create 
the required clock signal using alternative logic, but it would be neither practical nor economical to do so. 

The third device necessary in some 8086 microprocessor configurations is the 8288 Bus Controller. 

You will usually have an 8288 Bus Controller between an 8086 and its System Bus (or busses), just as you will usually 
have an 8288 System Bus controller between an 8080A and its System Bus. In the case of the 8086, however, you can 
dispense with the 8288 Bus Controller in single-bus configurations — and pay no penalty for it. 
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The 8086 has a large family of support devices. In this chapter we describe the following support devices: 

. The 8284 Clock Generator/Driver 
. The 8288 Bus Controller 

• The 8282/8283 8-bit input/output latches 

• The 8286/8287 8-bit parallel bidirectional bus drivers 

The 8088, an 8-bit version of the 8086, is also described. 

The primary manufacturer of the 8086 is: 

INTEL CORPORATION 

3065 Bowers Avenue 

Santa Clara, California 95051 

Second sources are: 

MOSTEK CORPORATION 

1215 West Crosby Road 

Carrollton, TX 75006 

NEC MICROCOMPUTERS INC. 

Five Militia Drive 

Lexington, MA 02173 

SIEMENS AG 

Components Group 

Balanstrasse 73, D8000 

Munich-80, West Germany 

The 8086 is manufactured using N-channel depletion load, silicon gate technology. It is packaged in a 40-pin DIP. A 
single +b V power supply is required. All signals, with the exception of the clock input, are TTL-level compatible. The 
clock input must be an MOS level signal; it is generated by the 8284 Clock Generator/Driver device, which is described 
later in this chapter. 

Instruction execution times will vary depending on how effectively instruction queuing is used. Typically, between 2 
and 30 clock cycles are required to execute an instruction. Multiplication and division instructions require more execu- 
tion time. Clock cycles may be as short as 125 nanoseconds. 

An 8 MHz version of the 8086 has been announced; it is identified as the 8086-2. The 4 MHz ver- 
sion is called the 8086-4. The standard 5 MHz 8086 is referred to without a suffix. There is no 
difference between the three versions other than maximum allowed clock speeds. 



8086 

8086-2 

8086-4 
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THE 8086 CPU 

Functions implemented on the 8086 microprocessor chip are illustrated in Figure 5-1. 

Interrupt priority arbitration logic is shown as only half present; external logic, such as an 8259A, must provide a 
device code identifying an interrupt, but all arbitration and vectoring logic is subsequently handled by logic within the 
CPU. 

It is worth noting that bus interface logic, which is shown as present in Figure 5-1, is much more extensive than other 
microprocessors provide. One could rightfully demand that bus interface logic therefore be shown as absent in equiva- 
lent figures for other microprocessors. 



Clock Logic 



Logic to Handle 
Interrupt Requests 

from 
External Devices 



Arithmetic and 
Logic Unit 



Instruction Register 



Control Unit 



interrupt Pnority 
Arbitration 



Bus Interface 
Logic 



I 



Accumulator 
Registei<s) 



Data Counters) 



Stack Pointer 



Program Counter 



Direct Memory 

Access Control 

Logic 



System Bus 



I 'O Communication 
Serial to Parallel 
Interface Logic 



Programmable 
Timers 



I 



ROM Addressing 

and 
Interface Logic 



I 



I/O Ports 
Interface Logic 



I 



RAM Addressirtg 

and 
Interface Logic 



Read Only 
Memory 



I/O Ports 



Read/Write 
Memory 



Figure 5-1. Logic of the Intel 8086 CPU 
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8086 AND 
8080A 
REGISTERS' 
COMPATIBILITY 



8086 PROGRAMMABLE REGISTERS AND ADDRESSING MODES 

We describe 8086 programmable registers in conjunction with 8086 addressing modes, since many 8086 pro 
grammable registers are there only to support memory addressing logic. 8086 programmable registers are il 
lustrated in Figure 5-2. 

Shaded registers are 8086 equivalents for 8080A registers, 8080A register names are shown in the left margin. 

Let us first examine the general purpose registers, AX, BX, CX, and DX. These locations 
are treated as four 16-bit registers or eight 8-bit registers; they also reproduce the 8080A 
general purpose registers as follows: 

AH has no 8080A equivalent. Do not confuse it with the 8080A PSW. 

AL is equivalent to the 8080A A register. 
BH is equivalent to the 8080A H register. 
BL is equivalent to the 8080A L register. 
CH is equivalent to the 8080A B register. 
CL is equivalent to the 8080A C register. 
DH is equivalent to the 8080A D register. 
DL is equivalent to the 8080A E register. 

Consistent with 8080A register utilization, register AX serves as a primary Accumulator. Input 
and output instructions pass data through AX (or AL) in preference to other general purpose 
registers; also, selected instruction access AX (or AL) contents only. 

In addition to serving as a general purpose Accumulator, register BX can serve as a base 
register when computing data memory addresses. 

Register CX serves as an Accumulator; it is also used as a counter by multi-iteration instruc- 
tions; these instructions terminate execution when register CX contents increment or decrement 
toO. 



8086 AX 
REGISTER 



8086 BX 
REGISTER 



8086 CX 
REGISTER 



Some I/O instructions move data between an identified I/O port and the memory location 8086 DX 

addressed by Register DX. Register DX may also serve as an Accumulator. REGISTER 

When looking at general purpose registers AX, BX, CX, and DX, there is plenty of opportunity to 
be confused by terminology. 

Intel literature identifies the four 16-bit registers via the labels AX, BX, CX, and DX. Each of these 16-bit registers is 
subdivided by Intel literature into two 8-bit registers, as follows: 



15 

7 




07 








<~ AX bit numbers 
■*-AH,AL bit numbers 

<- BX bit numbers 
■«- BH, BL bit numbers 

•<- CX bit numbers 
•<- CH, CL bit numbers 




AH 


1 


AL 




15 
7 




""ax" 

07 










BH 




BL 




15 
7 




""bx"" 

07 








CH 


CL 




15 

7 




CX 
07 








<r- DX bit numbers 
•«-DH, DL bit numbers 




DH 




DL 





The 8080A Accumulator must be reproduced by AL, since selected 8080A and 8086 instructions access this register 
and none other. 

BH and BL must reproduce the 8080A H and L registers, since only BX can contribute to an 8086 data memory address. 
On the surface this would appear to present a problem, since the 8080A has a limited number of instructions that use 
the BC and DE registers to provide 16-bit memory addresses. When 8080A source programs are reassembled to ex- 
ecute on an 8086 microprocessor, 8080A instructions that seek memory addresses out of the BC or DE registers 
become 8086 instructions that use Index registers. 
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A 
H, L 
B, C 
D, F 



07 



AH 


AU (or A) 


BH 


BL 


CH 


CL 


DH 


DL 




■*- One 16-bit register 
<r- Two 8-bit registers 

AX(=AH,AL) Primary Accun-iulator(s) 

BX (= BH, BL) Accumuiator(s). and Base register 

CX (= CH, CL) Accumulator(s) and Counter register 

DX (= DH, DL) Accumulators) and I/O Data Counter 



These names apply to 1 6-bit registers 
These names apply to 8-bit registers 



SP 



15 



■<- Bit number 

Stack Pointer (SP) 
Base Pointer (BP) 

■*~ Bit number 
Source Index (SI) 
Destination Index (Dl) 

<~ Bit number 
Program Counter (PC) 



I ndex registers 



15 



■*- Bit number 
Code Segment (CS) 
Data Segment (DS) 
Stack Segment (SS) 
Extra Segment (ES) 



Segment registers 



15 



•<- Bit number 
Status 



Shaded registers are 8086 equivalents for 8080A registers. 
8080A register names are shown in the left margin. 



Figure 5-2. 8086 Programmable Registers 
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All 8086 memory addresses are computed by summing the contents of a Segment register 
and an effective memory address. The effective memory address is computed via a variety of 
addressing modes, as it would be for any other microprocessor. The selected Segment register 
contents are left-shifted four bits, then added to the effective memory address to generate the ac- 
tual address output as follows: 



8086 

SEGMENT 

REGISTERS 



Segment Register contents: 
Effective memory address: 
Actual address output: 



XXXXXXXXXXXXXXXXOOO 
OOOOYYYYYYYYYYYYYYYY 
XXXZZZZZZZZZZZZZYYYY 



X, Y and Z represent any binary digits. 



Thus a 20-bit memory address is computed — which allows 1,048,576 bytes of external memory to be ad- 
dressed directly. 

The Segment registers of the 8086 are unlike any other microprocessor registers described in this book. They act as 
base registers which can point to any memory location that lies on an address boundary that is an even multiple of 16 
bytes. Using arbitrary memory addresses, this may be illustrated as follows: 

ly/lemory 
Address 



CS Segment register . 
contains 234E,, 



ES Segment register, 
contains 0A32iq 

DS Segment register _ 
contains 021 F,, 



334DF16 



234E016 



lASIFie 



CS segment 




ES segment 



DS segment 



As illustrated above, each Segment register identifies the beginning of a 65,536-byte memory segment. Since the 
8086 has four Segment registers, there will at any time be four selected 65,536-byte memory segments. The actual ad- 
dress output will always select a memory location within one of these four segments. For example, if an actual address 
output is the sum of the DS Segment register and an effective memory address, then the actual address output must 
select a memory location within the DS segment; that is to say, within the address range 021F0i6 through 121EFi6 in 
the illustration above. Likewise, an actual address output, which is the sum of the CS Segment register and an effective 
memory address, must select a memory location within the CS segment, which in the illustration above will lie in the 
address range 234E0i6 through 334DFi6- 

No restrictions are placed on the contents of Segment registers. Therefore, 8086 memory is not divided into 65,536- 
byte pages, nor do the four Segment registers have to specify non-overlapping memory spaces. Each Segment register 
identifies the origin of a 65,536-byte memory segment that may lie anywhere within addressable memory and may or 
may not overlap with one or more other segments. 

Even though Segment registers can create overlapping or non-overlapping segments, they do have dedicated address- 
ing functions. That is to say, different types of memory accesses compute memory address within specific seg- 
ments. 
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During an instruction fetch, tlie Program Counter contents are added to the Code Segment 
register (CS) contents in order to compute the memory address for the instruction to be fetched. 
This may be illustrated as follows: 





15 

7 


07 








AX = AH+AL 








BX = BH+BL 








CX = CH+CL 








DX = DH+DL 










15 









SP 






BP 






SI 






Dl 






PC 


M 


M M 


M 1 


\ 




15 







M M MM 


CS 


N 


N N 


" 1 






DS 




PPPPM 


SS 






ES 







8086 CODE 
SEGiVIENT 
REGISTER 
AND PROGRAIVI 
COUNTER 



Actual program memory 
address output. 



M, N, and P represent any hexadecimal digits. 
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Any Stack instruction such as a Push, Pop, Call, or Return adds the Stacic Pointer contents to 
the Stacl< Segment register (SS) contents in order to compute the address of the Stack location 
to be accessed. This may be illustrated as follows: 





15 
7 


07 






AX = AH+AL 






BX = BH+BL 






CX = CH+CL 






DX = DH+DL 








15 







SP 


M 


M M 


M 1 


BP 




SI 




Dl 




PC 






15 







CS 




DS 




SS 


N 


N N 


N 


ES 


1 



8086 STACK 
SEGMENT 
AND STACK 
POINTER 
REGISTERS 




P P PPM 



Actual Stack operation 
address output. 



Once again, M, N, and P represent any hexadecimal digits. 
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Instructions that process data strings use the SI and Dl Index registers, together with the 
Data Segment register (DS) and the Extra Segment register (ES), in order to identify string 
source and destination addresses. This may be illustrated as follows: 





15 
7 


07 






AX = AH+AL 






BX = BH+BL 






CX = CH+CL 






DX = DH+DL 







8086 EXTRA 

SEGIVIENT, 

SOURCE INDEX 

AND 

DESTINATION 

INDEX 

REGISTERS 





5 













SP 




\ 




BP 






SI 


J 


J 


J 


J 




Dl 


K 


K 


K 


K 








PC 




f 



Destination string address. 



K K K K 
N N N N 
R R R R K 





15 









M 


cs 




r 


DS 


M 


M 


M 


M 


/ , 


/ ' 


SS 




/ 


ES 


N 


N 


N 


N 


/ 



Source string address. 
J J J J 
•M MMMO 



S S S S J 



Actual data string 
address output. 



Actual data string 
address output. 



J, K, M, R, and S all represent any hexadecinnal digits. 

As the above illustration would innply, instructions that process strings require that the source and destination strings 
reside within a single 65,536-byte address range but not necessarily the same 65,536-byte range. 
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Instructions that access data memory add an effective memory address to the Data Seg- 
ment register (DS) or the Steele Segment register (SS). This may be illustrated as follows: 

Program 

Memory, 

as addressed 

by PC and CS 



8086 DATA 
SEGMENT 
AND STACK 
SEGMENT 
REGISTERS 





15 

7 


07 






AX = AH+AL 






BX = BH+BL 






CX = CH+CL 






DX = DH+DL 







15 



SP 
BP 
SI 
Dl 
PC 



CS 
DS 
SS 
ES 



15 



1. 




oxxxx 

Y Y Y YO 




Effective address segment base. 
Actual data address output. 



X, Y, and Z represent any hexadecimal digits. 

When a data memory address is created, as illustrated above, the BX, BP, SI, and Dl registers' contents, plus a displace- 
ment coming from the instruction object code, may contribute to the effective memory address. There are, however, 
very specific register and displacement combinations that can create an active memory address, as summarized in Ta- 
ble 5-1. Each case specifies either the DS or SS register as the default source for the segment base address. 
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Table 5-1. 


A Summary of Intel 8086 Memory Addressing Options 




IVIemory 
Reference 


Segment 
Register 


Base 
Register 


index 
Register 


Possible Displacements | 


16-Bit 
Unsigned 


8-Bit 

High-Order Bit 

Extended 


None 


Normal Data 
Memory 
Reference 


DS 

(Alternate*: 

CS, SS or ES) 


None 


SI 


X 


X 


X 


Dl 


X 


X 


X 


BX 


SI 


X 


X 


X 


Dl 


X 


X 


X 


None 


X 


X 


X 


DS 


None 


None 


X 






SS 

(Alternate*: 
CS, DS, or ES) 


BP 


SI 


X 


X 


X 


Dl 


X 


X 


X 


None 


X 


X 




Stack 


SS 


SP 


None 








String 
Data 


DS 


None 


SI 








ES 


None 


Dl 








Instruction 
Fetch 


CS 


PC 


None 








Branch 


CS 


PC 


None 




X 




I/O Data 


DS 


DX 


None 








* The segment override allows DS or SS to be replaced by one of the other segment registers 
X These are displacements that can be used to compute memory addresses. 



When creating any data memory address, you can add a prefix to an instruction to select a Segment register other than 
the default Segment register. You can only select a Segment register other than the default Segment register when ad- 
dressing data memory. You must live with the default Segment register when creating program memory addresses, 
Stack addresses, or string instruction addresses. 

It is very important to note that the 8086 has a whole set of data memory addressing options aimed at access- 
ing the Stack as though it were a data area. That is to say, in addition to the normal "Push" and "Pop" type Stack, in- 
structions, the 8086 allows normal data memory access instructions to address the Stack. Many assembly language 
programmers use the Stack to store addresses, and as a general depository for data that must be transmitted between 
program modules. Anyone favoring this assembly language programming philosophy will be delighted with 8086 data 
memory addressing options. 
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Let us now examine the various data memory addressing options In detail. Refer to Table 5-1. 

In the simplest case, we have straightforward direct memory addressing. A 16-bit displace- 
ment provided by two instruction object code bytes is added to the Data Segment register in order 
to create the actual memory address. This may be illustrated as follows: 



8086 DIRECT 

MEMORY 

ADDRESSING 





15 
7 


07 






AX = AH+AL 






BX = BH+BL 






CX = CH+CL 






DX = DH+DL 







15 



SP 
BP 
SI 
Dl 
PC 



M M M M 





15 









cs 


N 


N 


N 


N 


DS 


R 


R 


R 


R 


SS 




ES 






Actual data memory address output for 
direct memory addressing. 



,0 M M M M 




• N N NN 




PPPPM 




I 


Program 


\ 


Memory 




H H LL 
R RRRO 
S S S S L 




H H 



PPPPM 

PPPPM+1 

PPPPM+2 



H, L, M, N, P, R, and S all represent any hexadecimal digits. 

Note that a 16-bit address displacement, when stored in program memory, has the low-order byte preceding the high- 
order byte. This is consistent with the way the 8080A stores addresses in program memory. 

DS must provide the Segment base address when addressing data memory directly, as illustrated above. 
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Direct, indexed addressing is also provided. The SI or Dl register may be selected as the Index 
register. You have the option of adding a displacennent to the contents of the selected Index 
register in order to generate the effective address, if you do not add a displacement, then you 
have, in effect, implied memory addressing via the SI or Dl register. This may be illustrated as 
follows: 



8086 IIVIPLIED 

IVIEMORY 

ADDRESSING 





15 
7 




07 








AX = AH+AL 






BX = BH+BL 






CX = CH+CL 






DX = DH+DL 








15 











SP 




BP 




SI 




Dl 




PC 






15 











CS 


1 


DS 




R 


R R 


R 




SS 




ES 






Actual data memory address output for 
Implied memory addressing 



(You may substitute CS, SS or ES for DS by executing a 1 -byte instruction prefix.) 



X, R, and S represent any hexadecimal digits. 

If a displacement is added to the contents of the selected Index register, then you may 



8086 DIRECT, 

INDEXED 

ADDRESSING 



specify an 8-bit displacement or a 16-bit displacement. A 16-bit displacement is stored in two 
object code bytes; the low-order byte of the displacement precedes the high-order byte of the dis- 
placement, as illustrated for direct memory addressing. If "an 8-bit displacement is specified, then 
the high-order bit of the low-order byte is propagated into the high-order byte to create a 16-bit displacement. This 
may be illustrated as follows: 



Displacements: 
Sign extended: 



10 110 10 1 



1111111110110101 








( 


J C C) o| 



1 r 1 1 1 

110 10 11 



5-14 



We may now illustrate direct, indexed addressing as follows: 





15 
7 


07 






AX = AH+AL 






BX = BH+BL 






CX = CH+CL 






DX = DH+DL 









5 











SP 






BP 






SI 




) 


Dl 




n 


PC 


M 


M 


M 


M 







OM MMM 
NNNNO 





15 






0^ 


cs 


N 


N 


N 


N 


DS 


R 


R 


R 


R 


SS 




ES 





Actual data memory address output for 
direct. Indexed memory addressing. 




(You may substitute CS, SS or ES for DS by executing a 1 -byte Instruction prefix.) 

M, N, P, R, X, Y, and Z all represent any hexadecinnal digits. 

YYYY is the 16-bit or 8-bit displacement taken from program memory. 

XXXX is the index tal<en from either the Dl or the SI register. 

The effective memory address can be computed using base relative addressing. You have 



two sets of base relative addressing options: 

1) Data memory base relative addressing, which is within the DS segment (data memory). 

2) Stack base relative addressing, which is in the SS segment (Stack memory). 



8086 BASE 
RELATIVE, 
INDEXED 
ADDRESSING 
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Data memory base relative addressing uses the BX register contents to provide the base 
for the effective address. All of the data memory addressing options thus far described 
are available with base relative data memory addressing. In effect, base relative data 
memory addressing merely adds the contents of the BX register to the effective memory 
address which could otherwise have been generated. Here, for example, is an illustration of 
base relative direct addressing: 



8086 DATA 
MEMORY BASE 
RELATIVE 
ADDRESSING 



15 
7 



07 



AX = AH+AL 
BX = BH+BL 
CX = CH+CL 
DX = DH+DL 



SP 
BP 
SI 
Dl 
PC 







K K 


K K 











15 



M M M M 





5 











cs 


N 


N 


N 


N 




DS 


R 


R 


R 


R 




SS 




ES 





Program 
Memory 



Actual data memory address output for 
base relative, direct, indexed memory 
addressing. 




(You may substitute CS, ES or SS for DS by executing a 1 -byte instruction prefix.) 

Simple, direct addressing, which we described earlier, always generated a 1 6-bit displacement. Base relative, direct ad- 
dressing allows the displacement, illustrated above as HHLL to be a 16-bit displacement, an 8-bit displacement with 
sign extended, or no displacement at all. 
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Base relative implied data memory addressing simply adds the contents of the BX register to the selected Index register 
in order to compute the effective memory address. This may be illustrated as follows: 



15 

7 



AX = AH+AL 
BX = BH+BL 
CX = CH+CL 
DX = DH+DL 



SP 
BP 
SI 
Dl 
PC 



CS 
DS 
SS 
ES 



15 



15 



07 







K K 


K K 












sssss 



Actual data memory address output for 
base relative, implied memory addressing. 



(You may substitute CS, SS or ES for DS by executing a 1 -byte instruction prefix.) 
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Base relative, direct, indexed data memory addressing may appear to be complicated, but in fact it is not. We simply 
add the contents of the BX register to the effective memory address, as computed for normal direct, indexed address- 
ing. Thus, base relative, direct, indexed data memory addressing may be illustrated as follows: 



BX = BH+BL 
CX = CH+CL 
DX = DH+DL 



SP 
BP 
SI 
Dl 
PC 



CS 
DS 
SS 
ES 



15 
7 



07 



K K K K 



15 



M M M M 



15 



N N N N 



Actual data memory address output for 
base relative, direct, indexed memory 
addressing. 




(You may substitute CS, SS or ES for DS by executing a 1 -byte instruction prefix.) 
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The 8086 also has Stack memory addressing variations of the base relative, data memory addressing options just de- 
scribed. Here, for example, is base relative, direct Stack memory addressing: 





15 

7 


07 






AX = AH+AL 






BX = BH+BL 






CX = CH+CL 






DX = DH+DL 







15 



SP 
BP 
SI 
Dl 
PC 



K K K 



M M M M 



OM MM M 
NN NN 





15 









cs 


N 


N 


N 


" 1 


DS 




SS 


R 


R 


R 


« 


ES 


1 



Actual Stack memory address output for 
base relative, direct memory addressing. 



Program 
Memory 




(You may substitute CS, ES or SS for DS by executing a 1-byte instruction prefix.) 

In the illustration above, the displacement HHLL must be present, either as a 16-bit displacement, or as an 8-bit dis- 
placement with sign extended. Remember, base relative, direct data memory addressing also allows no displacement. 
However, base relative, direct Stack memory addressing requires a displacement. These options are summarized in Ta- 
ble 5-1. 
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Here is an illustration of base relative, implied Stack memory addressing: 



15 
7 


07 






AX = AH+AL 






BX = BH+BL 






CX = CH+CL 






DX = DH+DL 







15 



SP 
BP 
SI 
Dl 
PC 



K K K K 



15 



CS 
DS 
SS 
ES 



R R R R 




SSSSS 



Actual Stack memory address output for 
base relative, implied memory addressing. 



(You may substitute CS, DS or ES for SS by executing a 1 -byte instruction prefix.) 
X, R, and S represent any hexadecimal digits. 
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Here is an illustration of base relative, direct, indexed Stack nnennorY addressing: 





5 
7 07 


AX = AH+AL 






BX = BH+BL 






CX = CH+CL 






DX = DH+DL 









5 











SP 






BP 


K 


K 


K 


K 


-^\ 


SI 




kX 


Dl 




M \ 


PC 


M 


M 


M 


M 


\ \^ 


\ \*^ 



15 



CS 
DS 
SS 
ES 



N N N N 



Actual Stack memory address output for ^ 

base relative, direct, indexed memory addressing. 

(You may substitute CS, DS or ES for SS by executing a 1 -byte instruction prefix.) 




8086 I/O 

PORT 

ADDRESSING 



There is one anomolous 8086 addressing mode that can cause confusion. One variation of I/O in- 
structions addresses an I/O port via the DX register. The DX register contents are output on 
the Address Bus, to be interpreted as an I/O port address. This means you can have up to 65,536 
I/O port addresses. Since the DX register contents are being output as an I/O port address, it is not 
added to any Segment register contents. Thus, the DX register outputs an address in the range OOOOie through 
FFFFi6- This is the only case in which a register's contents are output directly as an address on the Address Bus, with- 
out first passing through segmentation logic. 

All 8086 Branch-on-Condition instructions use program relative addressing. This feature 
allows dynamically relocatable code. The Branch-on-Condition instruction provides an 8-bit, 
signed binary displacement that is added to the contents of the Program Counter. Thus, Branch- 
on-Condition instructions have an addressing range of -128 through -Hi 27 bytes from the loca- 
tion of the Branch-on-Condition. The queuing of instruction object codes has no impact on 
Branch-on-Condition logic, or the branch addressing range. 



8086 

PROGRAM 
RELATIVE 
ADDRESSING 
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8086 Jump and Subroutine Call Instructions offer these addressing options: 

1) Program relative addressing. An 8-bit or 16-bit displacement is added to the contents of the Progrann Counter. 

2) Direct addressing. New 1 6-bit addresses provided by the instruction are loaded into the Program Counter and the 
CS Segment register. 

3) Indirect addressing. Any of the data memory addressing options may be used to read data 
from data memory. However, the data input is interpreted as a memory address. You have two 
indirect addressing options. A single 16-bit data word may be read, in which case it is loaded 
into the Program Counter and the Jump or Call references a memory location within the cur- 
rent CS segment. You can also read two 16-bit data words; the first is loaded into the Program Counter and the 
second is loaded into the CS Segment register. Thus you can Jump or Call indirectly any addressable memory loca- 
tion. 

8086 STATUS 

The 8086 has a 16-bit Stack register with the following satus bit assignments: 



8086 

INDIRECT 

ADDRESSING 



15 14 13 12 1110 9 87654321 0- 



Bit No. 
Status register 

■ Reserved bits, normally 
Carry 

Parity 

Auxiliary Carry 
Zero 
Sign 
Trap 
• Interrupt enable/disable 

■ Direction 
Overflow 



The Carry, Auxiliary Carry, Overflow, and Sign statuses are quite standard; see Volume 1 for a description of these 
statuses. The Auxiliary Carry status is identical to the 8080A status with the same name. It represents carries out of bit 
3 in an 8-bit data unit as described in Volume 1, Chapter 2. 

Subtract instructions use twos complement arithmetic in order to subtract the minuend from the subtrahend. 
However, the Carry status is inverted. That is to say, following a subtract operation, the Carry status is set to 1 
if there was no carry out of the high-order bit, and the Carry status is reset to if there was a carry out of the 
high-order bit. The Carry Status therefore indicates a borrow. 

The Parity status is set to 1 when there is an even number of 1 bits in the result of a data operation; an odd number of 
1 bits causes the Parity status to be reset to 0. 

The Zero status is completely standard. It is set to 1 when the result of a data operation is zero; it is set to when the 
result of a data operation is not zero. 

The Direction status determines whether string operations will auto-increment or auto-decrement the contents 
of Index registers. If the Direction status is 1, then the SI and Dl Index registers' contents will be decremented; that is to 
say, strings will be accessed from the highest memory address down to the lowest memory address. If the Direction 
status is 0, then the SI and Dl Index register contents will be incremented; that is to say, strings will be accessed begin- 
ning with the lowest memory address. 

The Interrupt status is a master interrupt enable/disable. This status must be 1 in order to enable interrupts within 
the 8086. If this status is 0, then all interrupts except the NMI (Non-Masl<able Interrupt) will be disabled. 

The Trap status is a special debugging aid that puts the 8086 into a "single step" mode. The single step mode is de- 
scribed in detail together with 8086 interrupt logic, since it depends on this interrupt logic for its existence. 

The Carry, Auxiliary Carry, Parity, Sign, and Zero statuses are also found in the 8080A. The Overflow, Direction, 
Interrupt, and Trap statuses are new in the 8086. 
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8086 CPU PINS AND SIGNALS 

8086 CPU pins and signals are illustrated in Figure 5-3. 




vcc 

AD15 

A16/S3 

A1 7/S4 

A18/S5 

A19/S6 

BF?E/S7 

MN/MX 

RD 

RQ/GTO, HOLD 

RQ/GTT,HLDA 

LSCK,WR 

SI, M/iO 

ST, DT/R 

§0, DEN 

QSO, ALE 

qsi,1nTa 
TEST 
READY 
RESET 



Maximum 
System 
Signals 



Minimum 
System 
Signals 



Pin Name 


Description 


Type 


AD0-AD1 5 


Data/Address Bus 


Bidirectional, Tristate 


A16/S3, A17/S4 


Address/Segment Identifier 


Output, Tristate 


A1 8/S5 


Address/Interrupt Enable Status 


Output, Tristate 


A19/S6 


Address/Status 


Output, Tristate 


BHE/S7 


High-order Byte/Status 


Output, Tristate 


m 


Read Control 


Output, Tristate 


READY 


Wait State Request 


Input 


TEST 


Wait for Test Control 


Input 


INTR 


Interrupt Request 


Input 


NMI 


Non-maskable Interrupt Request 


Input 


RESET 


System Reset 


Input 


CLK 


System Clock 


Input 


MN/MX 


= GND for a Maximum System 




So, ST, S2 


Machine Cycle Status 


Output, Tristate 


RG/GTO, RQ/Gti 


Local Bus Priority Control 


Bidirectional 


QSO, QS1 


Instruction Queue Status 


Output, Tristate 


LOCK 


Bus Hold Control 


Output, Tristate 


MN/MX 


= Vcc ^0'' 3 Minimum System 




M/R5" 


Memory or I/O Access 


Output, Tristate 


WR 


Write Control 


Output, Tristate 


ALE 


Address Latch Enable 


Output, Tristate 


DT/R 


Data Transmit/Receive 


Output, Tristate 


DEN 


Data Enable 


Output, Tnstate 


INTA 


Interrupt Acknowledge 


Output 


HOLD 


Hold Request 


Input 


HLDA 


Hold Acknowledge 


Output 


Vcc. GND 


Power, Ground 





Figure 5-3. 8086 Pins and Signal Assignments 
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The 8086 outputs a 20-bit memory address. Data is accessed as 1 6-bit words, subdivided into a low-order byte and a 
high-order byte. Therefore the 8086 needs a 20-line Address Bus and a 16-line Data Bus. In order to have a 40-pin 
package, the low-order 16 Address Bus lines are multiplexed with the Data Bus. 

BHE may be looked upon as an additional Address Bus line, since it is used to identify the high-order byte of a 
memory word, while ADO identifies the low-order byte of the memory word. 

The four high-order Address Bus lines, together with BHE, are multiplexed with five status lines, thus, we can illustrate 
Address Bus line multiplexing as follows: 



Data/Status 



Address 



Status 

1 6-bit data word 

Status 



S7 

DO 

D1 -D15 

S3 - S6 



BHE High-order byte of selected word 
■ AO Low-order byte of selected word 

A1-A15 
■A16-A19 



Address of a 16-blt word 



It is easy to become confused when looking at how the Address Bus, together with BHE, is used 
to access memory. As seen by external memory. Address Bus lines are interpreted as follows: 



Select 



ADO 
AD1 



AD7 
ADS 



AD15 



A19 
BHE 



Memory 
select 
logic 



AO 



A18 



Low -order 

byte 

memory 

bank 



DO 



D7 



Select 



AO 



A18 



Memory 
select 
logic 



DO 



D7 



High-order 

byte 

memory 

bank 



8086 

EXTERNAL 
MEMORY 
ADDRESSING 



ADO 
AD1 



AD 7 
ADS 



AD15 



A19 
BHE 
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In the previous illustration you will see that mennory is indeed organized as bytes. 

The data pins of the low-order byte nnemory bank connect to AD0-AD7. The high-order byte memory bank data pins 
connect to AD8-AD15. 

The low-order and high-order byte memory banks each have memory select logic that decodes AD1 -A1 9. These 19 ad- 
dress lines become inputs A0-A1 8 at the illustrated memory select logic. Since each memory bank receives 1 9 address 
lines, select logic can address up to 524,288 (51 2K) bytes of nnemory. These two memory banks, taken together, con- 
stitute the advertised one million bytes of directly addressable memory. 

Now, you may well ask why one should bother dividing memory into separate low-order and high-order byte banks. If a 
sixteen-b it wo rd lies on an even-byte address boundary, then we could ignore the memory select logic connections to 
ADO and BHE. The address on AD1-A19 becomes an address identifying a 16-bit word, which just happens to be im- 
plemented as two separate 8-bit memory banks. 

If an 8086 16-bit memor y wo rd does lie on an even-byte address boundary, then the low-order byte address is, in fact, 
the only address output. BHE is pulsed low while the low-order byte address is being output, and both memory banks 
consider themselves selected even though (in theory) the high-order memory bank's address has not been output. 

To illustrate what happens, consider the memory addresses 02A40i6 and 02A41 ig- One would normally expect the 
two addresses to be output sequentially in order to access the low-order byte and then the high-order byte of the 1 6-bit 
word. This may be illustrated as follows: 



AD0-AD7 



AD8-AD1 5 



AD16-AD19 




Output 


Input 


Output 


Input 


address 


data 


address 


data 


02A40i6 


from 


02A41i6 


from 




byte 




byte 




02A40i6 




02A41i6 



But we could just as easily output the low-order byte address only, using BHE as an extra address line to substitute for 
the odd-byte address — which is never output. This may be illustrated as follows: 



AD0-AD7 



AD8-AD15 



AD16-AD19 




Output 




Input 


Input 


address 




data 


data 


02A40i6 


,, 


from 


from 




f 


02A40i6 


02A41 16 




Assume 








address 








02A4116 








has been 








output 







5-25 



If a word lies on an odd-byte address boundary, then two byte addresses must be output to access the two 
halves of the 16-bit word. This may be illustrated as follows: 



BHE 



\^^ 



<5^ 



AD1-AD7 



AD8-AD15 



<P 



I 



r^ 

AD16-AD19 X ^^— ^ 



Vka 



I 



I^IIZZDC 



nn 



I 






J I 



First memory 


Return low- 


Second 


Return high 


access is to 


crder byte 


memory 


order byte 


a byte In 


of 16-blt 


access is to a 


of 16-bit 


thehigli- 


word via 


byte in the 


word via 


order byte 


AD8-AD15 


low-order 


AD0-AD7 


memory 




byte memory 




banic, i.e. 




bank, i.e. 




an odd byte 




an even byte 




address, with 




address, with 




ADOIiigh 




ADO low 





When a 16-bit word lies on an odd-byte address boundary, as illustrated above, the low-order byte is input first via 
AD8-AD15, then the high-order byte is input via AD0-AD7. Logic internal to the 8086 switches the data bytes into 
their correction locations. 

Intel could have elected to implement external memory as 16-bit words, which would eliminate BHE along with 
the Address Bus complexities we have just described. But this would have forced all instruction object codes, 
and data, to be accessed as 16-bit units. Why not do it? 

One of the nnost interesting hindsight discoveries that 8080A users have made is the fact that the 8080A is extremely 
efficient in its use of memory. By having a large number of 8-bit object codes, the 8080A generates object programs as 
compact as the most powerful minicomputers on the market. 

But if the 8086 is to keep 8-bit object codes, and therefore the efficient memory utilization of the 8080A, then it can no 
longer guarantee that data will lie on even-byte address boundaries. The first 8-bit object code will force the next in- 
struction or data entity to begin on an odd-byte boundary. 

By including BHE and the extra logic needed to access 16-bit data units origined at odd-byte boundaries, the 8086 has 
allowed instructions to generate 1-byte, 3-byte or other odd-byte object codes, rather than 2-byte, 4-byte, and even- 
byte object codes only. 

Simply stated, this is the trade-off: simplify memory addressing so that external memory is accessed only as 
16-bit data units and you will use memory less efficiently. Intel elected to make memory addressing logic more 
complex and memory utilization more efficient. 

Moving on from the Data/Address Bus, 8086 signals may be grouped into those that do not change with system 
complexity, and those that do. Let us first look at the unchanging signals. 

CLK is the single clock signal output by the 8284 clock generator to synchronize all 8086 logic. 

READY is the Wait state request which slow external logic inputs if it requires more time to respond to an access. A 
high READY input occurring at the proper time early in a machine cycle causes the 8086 to extend the machine cycle 
by inserting Wait state clock periods. 
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8086 
RESET 



RD is a single bus control signal that does not change with system configuration. This signal is output low when the 
CPU is inputting data from any external source. 

Even though RD is output by the same physical pin under all circumstances, this signal is functionally part of the group 
that changes its nature depending on signal complexity. We will therefore refer again to RD when describing the sig- 
nals that are a function of system complexity. 

There are four interrupt and interrupt- related signals. 

INTR is a normal interrupt request input. 

NMI is a non-maskable interrupt request input. 

RESET is a system reset signal; it must be Input high to the 8284 clock generator for at least 
four CLK clock periods. The 8284 transmits a synchronized RESET signal to the CPU. When 
the 8086 is reset, the following events occur: 

1) The Status register is cleared. This disables external interrupts. 

2) The Program Counter and the three Segment registers, DS, SS, and ES, are cleared. 

3) The CS Segment register is set to FFFF-) 5. Following a Reset, program execution therefore restarts with the instruc- 
tion located at memory byte FFFFOig- 

These reset operations take approximately 10 clock periods to occur — during which time no other operations 
should occur. 

Following power-up, at least 60 microseconds should elapse before the 8086 is reset. 

An interrupt request via INTR should not occur sooner than 9 clock periods after the end of the 8086 device reset. An 
earlier interrupt request will cause one entire instruction to be executed before the interrupt request is recognized or 
acknowledged. 

A nonmaskable interrupt request should not be made during the first clock period following the end of a reset. 



TEST is not really an interrupt input, but it is used by program logic that otherwise would rely upon an interrupt. The 
80 86 has a special "Wait-for-Test" instruction that puts the CPU into an Idle state; this Idle state ends when 
the TEST input goes low. 

An 8080A (and other microprocessors) will duplicate the logic of the 8086 "Wait-for-Test" instruction by executing a 
"no operation" loop, which is terminated by an interrupt request: 

ENI Enable interrupts 

SELF JMP SELF Only an interrupt will ternninate loop execution 



5-27 



There are eight pins that can output one of two signals, depending on whether MN/MX is 
tied to power or ground. By having two sets of signals, the 8086 can be used in sinnple con- 
figurations, best served by elementary control signals, or in complex configurations, where control 
signals must provide sufficient information to resolve the contentions and access conflicts that 
complex microcomputer systems may encounter. 

The two sets of signals may be illustrated as follows: 
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8086 SIMPLE 

CONTROL 

SIGNALS 



Let us first look at the simple set of control signals that are output when MN/MX is con- 
nected to +5 V. These are completely standard microprocessor control signals. 

Since data and addresses are multiplexed on a single bus, ALE is output high to identify a valid 
memory address. 

When data are being transmitted or received via the Data/Address Bus, WR is pulsed low to identify data output, 
while RD is pulsed low as a request for external logic to place data on the Data/Address Bus. We have already 
described RD. It is not one of the changing signals; nevertheless, it is used by both simple and complex system busses. 

For a read or write operation, M/IO indicates whether memory (M/IO high) or an I/O port (M/IO low) is being ac- 
cessed. 

DT/R and DEN are two new control signals not found in earlier Intel microprocessors. Thiese two control signals have 
been designed specifically to control 8286/8287-type bidirectional transceivers. DT/R identifies the data direction, 
while DEN is the output enable. The 8286 and 8287 transceivers are described later in this chapter. 

HOLD and HLDA are standard hold request/acknowledge signals. When external logic inputs HOLD high, the 8086 
CPU enters a Hold state upon completing the current instruction's execution; the 8086 acknowledges the Hold State 
by outputting HLDA high. We will describe the Hold state in more detail later in the chapter. 

Let us now look at the complex System Bus that is generated when MN/MX is tied to 
ground. Control signals are output as a three-signal combination, decoded by a 3-to-8 decoder, 
and a two-signal combination, decoded by a 2-to-4 decoder. Complex System Bus signals have 
been designed to act as inputs to an 8288 Bus Controller. 

S2, 81, and SO are decoded to provide eight separate control signals. However, the simple system signals M/IO, DT/R 
and DEN represent a subset of the eight 32, SI, and SO combinations. In our earlier illustration, we identify this simple 
system subset by shading the applicable complex system S2, SI, and SO levels. 
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The eight combinations of S2, SI, and SO generate the following control signals: 

Interrupt acknowledge 

I/O device read 

I/O device write 

CPU has executed a HALT instruction and is in the Halt state 

The CPU is fetching an instruction object code byte 

Memory read 

Memory write 

The System Bus is inactive 

The control signal descriptions above use the words "read" and "write" as seen by the CPU. That is to say, a "read" 
operation moves data from a memory device or I/O port to the CPU, while a "write" operation moves data from the CPU 
to a memory location or I/O port. 

QSO and 081 combine to identify conditions within the 8086 instruction object code queue — which we will describe 
soon. The QSO and QS1 combinations are interpreted as follows: 

No operation. This is the default case 

The first instruction object code in the queue is being executed 

The queue is empty 

An instruction object code other than the first one in the queue is being executed 

Observe that the simple bus signals INTA and ALE do not correspond to any combination of QSO and QS1. This is in 
contrast to M/IO, DT/R and DEN, which constitute a subset of S2, SI, and SO. 
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LOCK, RQ /GT O. and RQ /GT1 are not related to their simple system equivalent signals: WR, HOLD, and HLDA. LOCK, 
RQ/GTO, and RQ/GT1 provide the 8086 with its System Bus priority and control logic in complex configurations. 



LOCK is output high to prevent the 8086 from losing bus control while executing a sequence of machine cycles that 
must not be interrupted. Typically these will be a memory access combination of read-modify-write machine cycles, 
where an error could result if the CPU lost bus control after the read and before the write. 

RQ/GTO and RQ/GT1 are two-bus priority, bidirectional type signals. They are used to determine which CPU in a nnulti- 
CPU configuration will at any time have control of a shared bus. We will discuss these signals in more detail later in the 
chapter when looking at the capabilities of the 8086 in multi-CPU shared bus configurations. 
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8086 TIMING AND INSTRUCTION EXECUTION 



The most important concept to understand when looking at 8086 instruction execution tim- 
ing is the fact the 8086 bus control logic has been separated from the 8086 instruction ex- 
ecution logic. That is to say, the 8086 has an Execution Unit (EU), and a Bus Interface Unit 
(BlU). 

The Execution Unit (EU) contains Data and Address registers, the Arithmetic and Logic Unit, 
plus the Control Unit. The Bus Interface Unit (BlU) contains bus interface logic. Segment 
registers, memory addressing logic, and a six-byte instruction object code queue. This may 
be illustrated as follows: 
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The Execution Unit (EU) and the Bus Interface Unit (BlU) operate asynchronously. Whenever 8086 

the Execution Unit is ready to execute a new instruction, it fetches the instruction object code INSTRUCTION 

from the front of the Bus Interface Unit instruction queue, then it executes the instruction in some QUEUE 

number of clock periods that have nothing to do with machine cycles. If the instruction object 

code queue is empty, then the Bus Interface Unit (BlU) executes an instruction fetch machine cycle — and the CPU 

waits for the instruction object code to be fetched. But the queue will rarely be empty, for reasons that will soon 

become apparent; therefore, the EU will usually not have to wait while an instruction fetch is executed. 
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8086 

INSTRUCTION 

QUEUE 



If memory or an I/O device must be accessed in the course of executing an instruction, then the EU informs the BlU of 
its needs. The BlU executes an appropriate external access machine cycle in response to the EU demand. 

The Bus Interface Unit (BlU), for its part, is independent of the Execution Unit (EU), and attempts to 

keep the six-byte queue filled with instruction object codes. If two or more of these six bytes are 

empty, then the Bus Interface Unit (BlU) executes instruction fetch machine cycles — providing 

the EU does not have an active request for bus access pending. If the EU issues a request for bus 

access while the BlU is in the middle of an instruction fetch machine cycle, then the BlU will complete the instruction 

fetch machine cycle before honoring the EU bus access request. 

8086 BUS CYCLES 

If we look at the way clock logic is used by the 8086, the term "machine cycle" no longer applies. The EU does 
not use machine cycles; it executes instructions in some number of clock periods that are not subject to any type of 
machine cycle grouping. The only time clock periods are grouped is when the bus control logic wishes to access 
memory or I/O devices. Each access requires four clock periods. This is the minimum amount of time required to han- 
dle the normal bus protocol that accompanies any transfer of information between a microprocessor and logic beyond 
the microprocessor. Since this is the only time the 8086 groups clock periods, it is more accurate to talk about 
8086 bus cycles, rather than machine cycles. 

Figure 5-4 illustrates two 8086 bus cycles executed back-to-back. In common with machine cycles, 8086 bus 
cycles, as illustrated in Figure 5-4 assign individual clock periods to time specific events. 

Memory and I/O device addresses are output on the Data/Address Bus during Ti. 

Data is transferred between the 8086 and memory or I/O devices during T3 and T4. If these two clock periods provide 
external logic with insufficient time to respond to an access, then Wait state clock periods (T\/\/) may be inserted bet- 
ween T3 and T4. 

T2 is a buffer clock period during which the Data/Address Bus stops outputting an address and starts outputting or in- 
putting data. 

During T4 the CPU identifies the status of the next bus cycle or clock period. In simple configurations when MN/MX is 
tied to -1-5 V, DT/R is the only external signal that changes state during T4. When MN/MX is tied to ground, SO, SI, and 
S2 change state during T4. Thus, by examining these three status outputs, external logic knows whether to expect 
another bus cycle, and, if so, what type of bus cycle. 

Now if you look at Figure 5-4, there is very little about it that differentiates an 8086 bus cycle from any other 
microprocessor's machine cycle. The characteristic of the bus cycle that differentiates it from standard machine 
cycles is the fact that bus cycles occur only on demand. 
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Figure 5-4. Two 8086 Bus Cycles 
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8086 INSTRUCTION QUEUE 

Consider what happens when an instruction is executed. Beginning with the simplest case, the instruction ob- 
ject code queue within the Bus Interface Unit will be empty. When the EU requests an object code byte there is 
none, so the Bill executes a bus cycle that fetches the first byte of the instruction object code: 
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Let US assume that this particular instruction requires two bytes of object code; keeping things simple, we will illustrate 
another instruction cycle executed immediately to fetch the next instruction byte: 
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Let US suppose that this instruction reads a word of data from memory, then performs an arithmetic operation using 
this data. The instruction is going to require some number of clock periods to compute the effective address for the 
data memory location to be accessed (we will assume seven clock periods are needed). Some additional number of 
clock periods will also be needed to perform the arithmetic operation (we will assume nine clock periods), in a normal 
microprocessor, this instruction might be executed as the following sequence of machine cycles: 
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But the 8086, having asynchronous CPU and Bus Control Unit logic, will use clock periods to execute the instruction 
lustrated above as follows: 
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Now, the illustration above is not accurate because, you will recall, the 8086 fetches data in 16-bit increments, pro- 
vided the data address lies on an even-byte boundary. Also, the BID fetches instruction bytes and loads them into the 
queue only when there are at least two free bytes in the queue. Let us assume that all data does lie on even-byte boun- 
daries. This is how our timing will now look: 



BIU 



Bus Cycle 1 
T1 ! T2 I T3 I T4 



Bus Cycle 2 
T1 I T2 ] T3 I T4 



EU EU asks for an 
object code byte. 
There are none, 
so the BIU exe- 
cutes a bus cycle. 



BIU fetches two 
bytes of object 
code In one bus 
cycle. The CPU 
takes both of 
them, so the 
queue is imnne- 
diately emptied. 



Bus Cycle 3 
T1 I T2 I T3 1 T4 



-/JlAAAAAAAAAA/VWtAAAAm^^ 



Bus Cycle 4 
T1 1 T2 i T3 I T4 



Bus Cycle 4 
T1 I T2 1 T3 I T4 



Ti 1 Ti I Ti I Ti 



The EU computes a data memory 
address in 7 clock periods. At the 
end of the 7th clock period the 
EU requests bus access. 



BIU fetches four bytes of object code 
in two bus cycles and stores them in 
the queue, which has two empty 
bytes left. 



The EU waits for the 
requested data to be 
fetched by the BIU. 



BIU fetches data 
from memory 
location addressed 
by the EU. 



I Ti I Ti I Ti I Ti 



The EU uses 9 clock periods to execute 
the arithmetic operation. 



The BIU fetches 
two more bytes 
of object code and 
stores them in the 
queue which is 
now full. 



I The BIU is idle. 



CLK 



Ti I Ti 1 Ti I Ti 

mnMm 

I Ti I Ti I Ti I Ti I Ti I I 
III I I I I 

The EU ends instruction execution 
and fetches one byte of object code 
from queue to execute next instruction. 

The BIU remains idle since only one 
byte of queue is empty. 



There are some important points to note regarding 8086 bus cycle timing. 

Bus cycles are a Bus Interface Unit (BIU) phenomenon. 

So far as the EU logic is concerned, bus cycles do not exist. The EU experiences periods of activity while executing in- 
structions, and periods of inactivity while waiting for instruction object codes or data that the BIU must process via bus 
cycles. Periods of EU activity are timed by a sequence of clock periods. The EU makes no attempt to group clock periods 
into machine cycles, nor do EU clock periods have to occur in any special numeric combinations. 

The EU asks for memory operands before it needs them, so unless the BIU cannot get immediate bus access the max- 
imum EU wait time is one cloclc cycle for bus access. 

So far as the BIU is concerned, clock periods are grouped into bus cycles only when data must be transferred to or from 
the 8086. First priority is given to a bus access request coming from the EU. If the EU is not requesting bus access, then 
the BIU executes instruction fetch bus cycles until the queue is full. These are the prerequisites for the BIU to ex- 
ecute an instruction fetch bus cycle: 

1) The clock period that initiates the bus cycle would otherwise be an idle clock period. 

2) The EU does not have an active bus access request pending. 

3) There are at least two bytes empty in the queue. 

If the queue is full, then the BIU ceases to execute bus cycles; as illustrated above, a sequence of idle clock periods oc- 
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Note that the CPU may have to wait for bus access. In the illustrations above, the EU requires seven clock periods in 
order to compute a data mennory address. At the end of the seventh clock period, the EU issues a bus access request to 
the BID. But at this tinne the BlU is part way through executing an instruction fetch bus cycle. The BlU completes the in- 
struction fetch bus cycle, then honors the EU bus access request. 

In the final illustration above, no bus cycle accompanies the beginning of a new instruction's execution. We are assum- 
ing that the next instruction executed has one byte of object code. This object code byte is fetched from the front of the 
queue — which then has just one empty byte. No bus cycle is executed to fetch the instruction object code, since it is 
taken out of the queue. Subsequently, the BlU does not execute an instruction fetch bus cycle since there is only one 
empty byte; there must be at least two empty bytes in the queue before the BlU will execute an instruction fetch bus 
cycle. 

Based on the foregoing discussion of 8086 instruction fetch queuing, we can see that the 8086 has essentially 
eliminated instruction fetch time. The only time the EU will have to wait while the BlU fetches instruction object 
codes is when a Branch-on-Condition instruction causes execution to branch out of the queue sequence, or when (for 
any reason) the memory accesses accompanying an instruction's execution are so dense that the BlU has insufficient 
idle clock periods within which to insert instruction fetch bus cycles. 

8086 MEMORY AND I/O DEVICE READ BUS CYCLE FOR MINIMUM MODE 

Figure 5-5 shows timing for an 8086 memory read bus cycle when MN/MX equals +5 V; that is to say. for the 
minimum mode bus configuration. 
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Figure 5-5. 8086 Memory Read Bus Cycle for a Minimum Mode System (MN/MX = -1-5 V) 
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The memory or I/O device address is output via the Address Bus BHE during clock period T-]. AD0-AD15 starts floating 
in T2 vvhile turning around internal pin logic so that data can be input during T3 and T4. Address lines A16 through 
A19 are all low when an I/O device address is being output. These address lines output status during T2, T3, and T4. 
Close to the end of T4, A16 through A19 start to float. 

BHE timing follows Address lines A16-A19; that is to say, BHE is output low for the time that A16 through A19 is out- 
putting an address. 

The trailing edge of the high ALE pulse should be used as the "valid address" strobe. If your 8086 configuration 
demultiplexes the Data and Address Busses, then the Address Bus demultiplexing buffers should be the "pass 
through" type and use the high-to-low transition of ALE as their latching strobe. 

Remaining control signals consist of M/IO and RD, which are directed at external memory or I/O devices, plus DT/R and 
DEN, which are directed at bus buffers. 

M/IO differentiates between a memory access and an l/Odevice access. M/IO will be high for a memory access bus cy- 
cle; it will be low for an I/O device access bus cycle. M/IO will contribute to memory and I/O device select logic when 
memory and I/O devices have similar addresses. 

RD is pulsed low as a memory or I/O device read strobe. The addressed memory device must use this low signal to 
place data on ADO - AD15. 

DT/R and DEN are control signals designed to control bidirectional latched buffers on the Data Bus. DT/R is output low 
for the entire memory or I/O device read bus cycle; it should be used to turn the latched buffers around so that they will 
transmit data to the CPU. DEN subsequently acts as a latching strobe. These two signals have been designed 
specifically to work with the 8286 and 8287 Data Bus transceivers; however, their logic is quite general. 

There is no difference between external timing for an instruction fetch or memory read bus cycle. Given the 
pipelining instruction fetch logic of the 8086, this makes sense. 

The_only timing difference between a memory read bus cycle and an I/O device input bus cycle occurs at the 
M/IO signal. This signal will be low for the duration of an I/O input bus cycle, whereas in Figure 5-5 it is shown high 
for the duration of a memory read bus cycle. 

Except for this difference. Figure 5-5 also illustrates I/O input bus cycle timing for a simple 8086 configuration. 

During any simple configuration memory access operation, the following status is output on address lines A16 
through A19: 

A19/S6 — Always 
A18/S5 — Interrupt enable status 
A17/S4— 1 1 

A16/S3— 1 1 

Data segment access 

Code segment access or no access 

Stack segment access 

Extra segment access 



t 



The interrupt enable status appearing on A18 nnay be used to illuminate an indicator on a control panel, should there 
be one. This indicator will show whether interrupts are enabled or disabled at any time. This status has no other value. 

S3 and S4 together identify the memory segment which is being accessed. This is not very useful information. 

Even a code segment access cannot be interpreted as an instruction fetch, since data can be addressed out of the pro- 
gram segment. 

8086 MEMORY OR I/O DEVICE WRITE BUS CYCLE FOR MINIMUM MODE 

Figure 5-6 illustrates tim ing f or an 8086 memory or I/O device write bus cycle when the 8086 is operating in a 
minimum mode with MN/MX tied to +5 V. 

Address output logic is identical in rea d and write bus cycles. As was the case for a read bus cycle, the address is out- 
put on the Address Bus, together with BHE, during T-\ . External logic should use the high-to-low transition of the ALE 
pulse in order to latch a valid address. During T2, ADO - AD15 switches to outputting data, while A16 - A19 outputs 
status. The same status is output in read and write bus cycles. 

M/IO is output high for the duration of a memory write bus cycle; it is output low for the duration of an I/O device write 
bus cycle. 

WR is output low beginning early in T2 and ending shortly after T3. Note that RD does not go low for a read bus cycle 
until halfway through T2. 
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For an 8286 or 8287 Bus Transceiver, or any similar device, DT/R is output high for the entire duration of the write bus 
cycle. This conditions the device to transmit data from the CPU to external logic. DEN is the chip enable signal provided 
for the bus transceiver. DEN is output high from the end of Ti until the end of T4. Note that this high pulse is longer 
than the DEN pulse accompanying a read bus cycle. 
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Figure 5-6. 8086 Memory Write Bus Cycle for a Minimum Mode System (MN/MX = -1-5 V) 

An I/O write bus cycle has timing identical to Figure 5-6, except that the M/iO signal will be low for the duration of the 
bus cycle, rather than high as shown in Figure 5-6. Wherever a memory word and an I/O port may have the same ad- 
dress, M/iO must contribute to device select logic in order to discriminate between memory and I/O devices. 

The status output on A16-A19 is no more useful in a write bus cycle than it is in a read bus cycle. 

8086 READ AND WRITE BUS CYCLES FOR MAXIMUM MODE 

It is not very rewarding looking at maximum mode memory or I/O access bus cycle timing, if we look at timing for an 
8086 device on its own. This is because in maximum mode, with MN/MX tied to ground, the 8086 has been designed 
to operate with the 8288 Bus Controller. 

Figure 5-7 and 5-8 provide maximum mode timing for the 8086 on its own when executing read or write bus cycles. 
Only the status signal levels differentiate memory or I/O access bus cycles. 

Timing for the Address/Data Bus is identical in minimum and maximum modes. The read strobe RD does not change. 
However, remaining control signals become control inputs to the 8288 Bus Controller. 
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Observe that QSO and QS1 change levels on a clock period by clock period basis in order to identify events for in- 
dividual clock periods. SO, SI, and S2 hold their levels from shortly before Ti until shortly after the end of 12- 
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Figure 5-7. 8086 Memory or I/O Read Bus Cycle for a Maximum Mode System (MN/MX = V) 
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Figure 5-8. 8086 Memory or I/O Write Bus Cycle for a Maximum Mode System (MN/MX = V) 
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The 8288 Bus Controller, described later in this chapter, decodes SO, SI, and S2 in order to generate control signals 
that are comparable to those illustrated in Figures 5-5 and 5-6. For a complete discussion of bus cycle timing in com- 
plex 8086 microcomputer configurations, see the discussion of 8288 Bus Controller. 

THE 8086 WAIT STATE 

8086 Wait state logic is independent of the IVIN/MX pin connection and the external access bus cycle being ex- 
ecuted. In any bus cycle it is possible to insert one or more Wait clock periods (Tyv) between T3 and T4. In order to ex- 
tend a bus cycle with Wait clock periods, external logic must input a low READY signal during T2 of the bus cycle 
which is to be extended. The READY input to the 8086 must be synchronized with the falling edge of CLK at the end of 
T2; this synchronized READY input is created by the 8284 clock generator. External logic will normally input an 
asynchronous READY to the 8284 clock device, which outputs a synchronous READY for the 8086. Wait clock periods 
will continue to be inserted to the bus cycle until READY goes high again. Timing is illustrated in Figure 5-9. All out- 
put signal levels are maintained for the duration of the Wait state. 

THE 8086 HOLD STATE 

The 8086 can be forced into a Hold state, at which time all three-state signals are floated. The 8086 Hold state 
is used to enable direct memory access logic, and in addition to disable inactive 8086 devices when more than 
one CPU accesses the same System Bus in a multi-CPU configuration. 

In a minimum mode configuration, when MN/MX is tied to -t-5 V. the 8086 has a traditional 
Hold request input (HOLD) and a Hold Acknowledge output (HLDA). Upon receiving a high 
HOLD input, the 8086 will complete execution of its current instruction bus cycle before entering 
the Hold sate and outputting HLDA high. Timing may be illustrated as follows: 



8086 HOLD 
IN MINIMUM 
MODE SYSTEM 



I T4 or Ti I 



CLK 



HLDA 




The 8086 samples the HOLD input on the low-to-high transition of CLK. Therefore, HOLD must make its transitions 
away from this sampling point; that is to say, HOLD must be stable when CLK is making its low-to-high transition. 

The 8086 will acknowledge the Hold request by making HLDA high during any idle clock period, or at the end of a bus 
cycle. If a bus cycle is being executed when a Hold request occurs, the Hold request will not be acknowledged until the 
end of T4 for the currently executing bus cycle. 

The Hold state will last until the HOLD input goes low again. The 8086 continues to sample the HOLD input on all low- 
to-high transitions of CLK; therefore, HOLD must make its high-to-low transition away from the rising edge of CLK. 
When HOLD goes low, the Hold state will immediately end and HLDA will be forced low again. 

In 8086 maximum mode configurations where MN/MX is tied to ground, the HOLD a nd H LDA 
pins con vert to bid irectional type control signal s. Th ere are two bidirectional signals; RQ/GTO and 
RQ/GT1. RO/GTO has higher priority than R0/GT1. 



8086 HOLD 
IN MAXIMUM 
MODE SYSTEM 
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Figure 5-9. The 8086 READY Input and Wait States 

Any external logic that wishes to put an 8086 CPU into the Hold state transmits a low pulse to RQ/GTO or RQ/GT1. The 
8086 CPU will acknowledge this Hold request immediately, if a bus cycle is not being executed, or at the conclusion of 
a currently executing bus cycle. The 8086 acknowledges the Hold request transmitting by a low pulse via the same RQ/ 
CTline; simultaneously the 8086 floats its three-state bus lines. External logic must allow at l east one clock period to 
elpase following the Hold Acknowledge pulse, before attempting to input via the same pin. External logic terminates 
the Hold state by inputting another low pulse. Timing may be illustrated as follows: 




RQ/GT 



in the illustration above, @ identifies the instant at which external logic requests a Hold state by transmitting a low 
pulse via either RQ/GT line. The 8086 samples RQ/GT on the rising edge of CLK; therefore, all signal transitions on 
RQ/GT must occur away from the CLK low-to-high transitions. 

The 8086 will now acknowledge a Hold request during a bus cycle. If a bus cycle is in progress, then the Hold 
acknowledge will occur at the end of the bus cycle — that is to say, at the end of T4. If a bus cycle is not in progress, 
then the Hold request will be acknowledged immediately. In the illustration above, (|) identifies the low pulse the 
8086 will output as its Hold acknowledge. The Hold state will last until external logic again transmits a low pulse via 
RQ/GT. This is identified above as (C) Once again the 8086 samples RQ/GT on the rising edge of CLK; therefore, 
RQ/GT should be stable at this time. 

When the 8086 enters the Hold state, it continues executing instructions it tal<es out of the pipeline, until a bus 
access is required. When the EU requires a bus access, it stops operating until the end of the Hold state — at which 
time its bus access request will be honored by the Bus Interface Unit. 

In the eve nt that Hold requ ests occur simultaneously on RQ/GTO and RQ/GT1, the acknow ledge pulse will be 
output on RQ/GTO, RQ/GT1 will not be acknowledged until the Hold state initiated via RQ/GTO has ended. 

When one Hold state ends, another Hold state can begin immediately for either of these reasons: 

1) RQ/GT1 was active when RQ/GTO was acknowledged; the RQ/GT1 Hold request, being of lower priority, was 
denied and is pending. 

2) While the 8086 was in a Hold state, a new hold request occurs on the other RQ/GT line. 

If a new hold request occurs while the 80 86 i s in Hold state, priorities no longer apply. For example, if the CPU has 
acknow ledg ed a Hold request occurring at RQ/GT1 and is in a Hold state, then it will deny a new Hold request arriving 
via RQ/GTO until the current Hold state has ended. 
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If there is an active Hold request when the CPU ends a Hold state, then the CPU will immediately acknowledge the 
pending Hold request. This may be illustrated as follows: 



Hold for RQ/GT1 in progress 



Hold for RQ/GTO in progress 



Low pulse End RQ/GT1 Hold 

Input at and immediately 

RQ/GTO stand RQ/GTO Hold 

When a Hold state ends, if the CPU has a bus access request pending, then the CPU bus access request will be denied 
until all active Hold requests have been acknowledged. 

Note that there are no 8086 instructions that specifically affect the level of RQ/GTO orRQ/GTI. That is to say, external 
logic is entirely responsible for the interfaces to these two signals. 

We will discuss RQ/GTO and RQ/GT1 in more detail later in this chapter when we look at some multiple CPU 8086 con- 
figurations. 

THE 8086 HALT STATE 

The 8086 enters a Halt state after a HALT instruction is executed, in the Halt state no signals are floated, and 
undefined data is output on the Data/Address Bus. No bus cycles can be executed while the 8086 is in the Halt 
state. 

When a Halt instruction is executed, a bus cycle initiates the Halt state. This Halt state initializing bus cycle has 
nothing to do with instruction fetch logic. If the Halt instruction object code is fetched by the CPU from the queue, then 
there will be no preceding instruction fetch bus cycle. If the Halt instruction must be fetched from memory because the 
queue is empty, or is at the conditional end of a Branch-on-Condition, then the Halt initializing bus cycle will be pre- 
ceded by an instruction fetch bus cycle. 

For a simple system, the HALT initialization bus cycle is given by Figure 5-5, except that RD, M/iO, DT/R and 
DEN are not active. ALE is active, although the address output has no meaning. 

For a complex system, the HALT initializing bus cycle is illustrated in Figure 5-10. The Halt state combination 
occurring at SO, SI, and S2 causes the 8288 Bus Controller to issue an ALE pulse before entering the Halt state; 
however, the occurrence of ALE could not be deduced simply by looking at 8086 timing. 
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Figure 5-10. 8086 HALT Instruction and Bus Cycle Timing for a Connplex Bus Configuration 

The Halt state is terminated by an interrupt request or a Reset. 

You can freely enter and leave a Hold state within an 8086 Halt state via any of the means that we have just de- 
scribed. The fact that the 8086 is in the Halt state in no way nnodifles Hold logic. 

THE 8086 LOCK 

A potential for serious error exists in the Hold request/acknowledge logic of the 8086. 

The 8086 will acknowledge a Hold request occurring on the RQ/GTO or RQ/GT1 lines at the end of the current bus cy- 
cle, if one is being executed, or at the next idle clock period, if a bus cycle is not being executed. The 8086 does not 
wait until the conclusion of the current instruction's execution before acknowledging the Hold request. Therefore, if an 
instruction reads the contents of a memory location (or I/O port), modifies these contents, then writes it back, a Hold 
state may separate the read bus cycle from the write bus cycle: 



Read from memory location X 



Modify data 



Write back to location X 



HOLD STATE 



This can cause unexpected errors. If the 8086 enters a Hold state after reading memory location X contents and before 
writing these contents back, then it is possible for external logic — either direct memory access logic or another 
Central Processing Unit — to modify the contents of memory location X while the 8086 is in the Hold state. Now when 
the 8086 writes back the modified word, it may destroy data that should have been preserved. 
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If a 16-bit data word lies on an odd- byte boundary, it will require two bus cycles to access the data word. Undernormal 
circumstances, a Hold request could be acknowledged between the first and second memory access bus cycles. But 
what if the word being accessed gets modified during the Hold state? If the Hold state splits two memory read bus cy- 
cles, this is what the CPU is going to read: 



7 7 



High-order byte 

was read after Hold 

and is modified 



Low-order byte 

was read before Hold 

and is not modified 



If a Hold state splits two memory write bus cycles, this is what ultimately gets written: 
7 7 



High-order byte 
is written after Hold 
and is not modified 



Low-order byte 

was written before Hold 

and gets modified 



You use the 8086 LOCK instruction in order to prevent the types of errors described above. 



When a LOCK instruction is executed, the LOCK signal is low for the duration of the next sequential instruc- 
tion's execution. Also, while the next sequential instruction is being executed, a Hold request will not be 
acknowledged. 

You cannot extend protection against a Hold acknowledge beyond a single instruction's execution. For example, sup- 
pose you have two instructions, each of which is preceded by a Lock: 



LOCK 




AND 


MEMX, AX 


LOCK 




OR 


MEMX, BX 



In the instruction sequence above, MEMX is a label which represents the address of a memory location. The contents of 
this memory location are ANDed with a mask stored in AX, then ORed with a mask stored in BX. The contents of MEMX 
are read, modified, and written back at each step. 

Now, you may wish to inhibit Hold logic for both the AND and the OR operation. You cannot do so using the LOCK in- 
struction. The first LOCK instruction will protect the following AND instruction from being interrupted by a Hold state: 
however, any pending Hold state will be acknowledged before the second LOCK instruction is executed. 

Each LOCK instruction extends protection against a Hold Acknowledge for the duration of the next sequential instruc- 
tion only. The fact that the following instruction is also a LOCK is irrelevant. The second LOCK instruction will be the 
first instruction executed following the Hold state, and it will guarantee that no new Hold state begins until it, and the 
OR instruction, have both been executed. 

You can use the LOCK instruction and signal to identify individual instruction execution 
times. If for any reason external logic needs to know the execution time for certain instructions, 
then by preceding these instructions with a LOCK instruction you will generate a high pulse on 
the LOCK output. The width of this high pulse exactly equals the execution time of the instruction 
which follows the LOCK. 

THE 8086 PROCESSOR WAIT FOR TEST STATE 



8086 SINGLE 
INSTRUCTION 
TIME 
IDENTIFIED 



The 8086 has a program-initiated Wait state that external logic must terminate via the TEST input signal. The 

WAIT instruction initiates this Wait state. After the WAIT instruction is executed, the 8086 g enerat es an endle ss se- 
quence of idle clock periods. This sequence lasts until external logic inputs a low signal at the TEST input. TEST must 
be high for at least four clock periods. 

While the endless sequence of idle clock pulses is being executed, the System Bus is not floated and the Bus Interface 
Unit may execute memory read bus cycles in order to fill up the instruction object code queue. 
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The processor Wait state can be used to synchronize an 8086 with any external time sequence. For example, you 
could start two programs, executing in two separate 808 6 syst ems, at exactly the same time, by preceding each pro- 
gram with a Wait instruction. If both 8086's receive low TEST inputs simultaneously, then both microprocessors will 
start executing their programs at the same instant. 

THE 8086 PROCESSOR ESCAPE 

The 8086 has a special escape instruction (ESC) intended for use in multi-CPU configurations. When the ESC instruc- 
tion is executed, the contents of an addressed memory location are input to the CPU, but the input data is not 
stored anywhere. The purpose of the ESC instruction is to place the addressed data on the Data/Address Bus so that 
any other microprocessor (or external logic) connected to the Data/Address Bus can receive the data. 

We will examine the value of the ESC instruction later in the chapter when looking at the 8086 in multiple CPU 
configurations. 

THE 8086 RESET OPERATION 

The 8086 has an asynchronous RESET input. This signal can be forced high at any time in order to reset the 
8086. The high RESET must be at least four clock cycles long. 

The 8086 terminates all current operations as soon as the RESET input makes a low-to-high transition. Nothing 
more happens until the RESET signal subsequently makes a high-to-low transition. It then takes approximately 
ten clock periods in order to execute the following operations: 

1) The Status register is cleared. Among other things, this resets the interrupt enable flag to 0, thus disabling inter- 
rupts. 

2) The CS Segment register is set to FFFFis- 

3) The DS, SS, and ES Segment registers and the Program Counter are all reset to 0. 

4) Program execution begins. Since the CS Segment register contains FFFF-js and the Program Counter contains 0, 
the first instruction executed is taken from memory location FFFFOis- 

8086 INTERRUPT PROCESSING 

The 8086 allows interrupts to originate in one of three ways: 

1) From software or within program logic. 

2) From external logic as a nonmaskable interrupt. 

3) From external logic as a maskable interrupt. 

There is, in addition, a special "single step" condition that makes use of interrupt logic. We will describe single step- 
ping after our discussion of interrupt logic. 

In the event that two or more of the three interrupt types occur simultaneously, software generated interrupts have the 
highest priority and maskable interrupts have the lowest priority. 

These are the ways in which a software interrupt request may occur: 

1) Following an attempt to divide by 0. A special divide by interrupt request will occur any 
time the divide instruction is executed with a dividend. 



8086 

SOFTWARE 

INTERRUPTS 



2) Following execution of an Interrupt instruction (INT). 

3) Following execution of an Interrupt-on-Overfiow instruction (INTO) — if the Overflow status is set 
A nonmaskable interrupt request is initiated when external logic transmits a low-to-high 



transition to the NMI pin. This is an edge-triggered signal. A nonmaskable interrupt has lower 
priority than a software interrupt, but higher priority than a maskable interrupt. 

A maskable interrupt request will be generated when external logic transmits a high level to 
the INTR pin. This input is level sensitive; it is the high level at INTR that causes the interrupt re- 
quests to occur. 

Central to all 8086 interrupt processing is a Vector table that can be up to 1024 bytes in 
length, occupying absolute memory addresses 00000 through OOSFF-jg. This Vector table con- 
sists of up to 256 four-byte entries. Each entry contains two 16-bit addresses that get loaded into 
the CS Segment register and the Program Counter. 

Figure 5-11 illustrates the 8086 Interrupt Vector table. 
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A number of the Vector table entries serve specific interrupts. Other entries are reserved by Intel and should be 
avoided if compatibility with Intel software is desired. These entries are identified in Figure 5-11. As illus- 
trated in Figure 5-11, 32 of the 256 interrupt vectors are not available to external logic; that leaves 224 vec- 
tors available to maskable external interrupts — which is plenty. 

Taking each of the three interrupt types in turn, let us examine the interrupt acknowledge process. 

When any of the software interrupts are acknowledged, the following steps occur: 

1) The Status register contents are pushed onto the Stack; Stack Pointer contents, in conse 



8086 

SOFTWARE 

INTERRUPT 



quence, are decremented by two. 

2) The Interrupt and Test status flags are cleared; this disables maskable interrupts and single 
step logic (which we describe after our discussion of interrupt logic). 

3) The CS Segment register contents are pushed onto the Stack; Stack Pointer contents, in consequence, are decre- 
mented by two. 

4) The new CS Segment register contents are taken from the appropriate interrupt vector location. With the excep- 
tion of the INT instruction, software-generated interrupts have dedicated vector locations as illustrated in Figure 
5-1 1. The INT instruction allows any one of the 256 vector locations to be selected; a default option selects Vec- 
tor 3. 

5) The Program Counter contents are pushed onto the Stack; Stack Pointer contents are decremented by two. 

6) The new Program Counter contents are taken from the interrupt vector. 
When a nonmaskable interrupt is acknowledged, the following events occur: 

1) The Status register contents are pushed onto the Stack. The Stack Pointer contents are 
decremented by two. 

2) The Interrupt and Test statuses are reset to 0; this disables nonmaskable interrupts and 
single stepping mode. 

3) The CS Segment register and Program Counter are reloaded from Interrupt Vector 2. See Figure 5-1 1 
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When a maskable interrupt is acknowledged, the following steps occur: 

1) Two interrupt acknowledge bus cycles are executed by the Bus Interface Unit of the 8086. An 
interrupt acknowledge bus cycle is identical to the memory read bus cycles, as illustrated in 
Figures 5-5 and 5-7, with the exception that an interrupt ackno wledge low pulse replaces 
the memory read low pulse. For a minimum mode system, INTA will provide the low RD pulse shown in Figure 
5-5. Figure 5-7 accurately illustrates timing for an interrupt acknowledge bus cycle in a maximum mode system; 
however, SO, SI, and S2 will all be low, identifying an int errupt acknowledge, whereas a read I/O port or read 
memory status combination would be output otherwise. LOCK is low beginning at T2 of the first interrupt 
acknowledge bus cycle and ending at T2 of the second interrupt acknowledge bus cycle. This may be illustrated as 
follows: 




LOCK 



2) The acknowledged external device must send back a byte of data on lines AD0-AD7 in response to the second in- 
terrupt acknowledge bus cycle. This data byte is interpreted as a pointer into the interrupt vector. Multiplying this 
8-bit value by 4 creates the correct beginning address for the interrupt vector. 

3) The Status register contents are pushed onto the Stack. 

4) The Interrupt and Test flags in the Status register are cleared. This disables further maskable interrupts and single 
step logic. 

5) The CS Segment register contents are pushed onto the Stack. 

6) The next CS Segment register contents are taken from the interrupt vector location identified in Step 2. 

7) The Program Counter contents are pushed onto the Stack. 
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Figure 5-11. 8086 Interrupt Vector 

8) The new Program Counter contents are taken from the interrupt vector location identified in Step 2 

9) The first instruction of the interrupt routine is fetched using the new PC and CS. 

It takes 60 clock periods to complete the nine interrupt acknowledge steps listed above. 

You should use the (RET instruction to exit any interrupt service routine. This instruction 
restores Program Counter, CS Segment register, and Status register contents from the 
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SINGLE STEPPING MODE 

When the T status bit is set to 1, the 8086 operates in single stepping mode. In the single stepping mode the 8086 
executes a software interrupt after each instruction's execution. The software interrupt vectors through Location 1 of 
the interrupt vector table, as illustrated in Figure 5-1 1. 

Since the process of acknowledging an interrupt resets the TF flag, the singlie stepping mode will cease to exist once 
the interrupt service routine identified by Vector 1 is executed. But since the Status register contents prior to the inter- 
rupt acknowledge are saved on the Stack and are restored when a return from interrupt instruction is executed, single 
stepping mode will be restored as soon as the interrupt service routine corresponding to Interrupt Vector 1 concludes 
execution. Interrupt Vector 1 should therefore vector to a debug routine. Any user program executed in the single step 
mode will now execute instructions one at a time, branching to the debug program following execution of each instruc- 
tion. 

A particularly pleasing aspect of the 8086 single step mode is the fact that it can cope with interrupt logic. Fre- 
quently, microprocessor programs cannot be debugged once interrupt logic is introduced. In the case of the 8086, the 
interrupt acknowledge process automatically takes the 8086 out of the single step mode. You can insert instructions 
into any interrupt service routine in order to restore single stepping mode for that particular interrupt service routine. 
Thus, you have the option of executing any program or interrupt service routine in single step mode, without impacting 
any other program or interrupt service routine. 

THE 8086 INSTRUCTION SET 

The 8086 instruction set is summarized in Table 5-4. When compared to other microprocessor instruction sets, the 
8086 instruction set might appear quite large. If you look at Table 5-4, you will see that a single instruction mnemonic 
may appear many times. In reality, these are variations of the same instruction. We show the variations of a single in- 
struction as though they were separable instructions in order to make this description of the 8086 instruction set con- 
sistent with similar tables for other microprocessors. 

The two I/O instructions. IN and OUT, become eight instructions because each has two sets of options. 

Each I/O instruction can access 16-bit words or 8-bit bytes. In each case, the instruction may have a short addressing 
range or a long addressing range. The short addressing range instruction requires two bytes of object code and can ac- 
cess one of the first 256 I/O port addresses. The I/O address is specified in the second object code byte. The long-range 
I/O instructions occupy only one byte of object code; however, register DX provides the I/O port address — which can 
therefore range between and 65,535io- 

Primary memory reference instructions, and memory reference instructions in general, all have byte and word 
versions. In Table 5-4, the data memory location accessed is identified by the operand label DADDR. Because 
data memory reference instructions may or may not include a displacement, the object code may be two, three, or four 
bytes long, as defined in Table 5-5. 

By preceding any data memory reference instruction with the SEG prefix, you can force the data memory reference to 
access a segment other than the data segment. Here, for example, are the two instructions that load a byte of data from 
the extra segment to Register AL, using direct, indexed addressing: 

SEG ES Select extra segment 

MOV AL, (Dl) ADDR Load data word from extra segment 

The LEA and LES instructions are unusual in that they load a memory address, rather than the contents of a memory 
location, into an identified 16-bit register. For the LEA instruction, this may be illustrated as follows: 



LEAAX,(DI) ADDR 



AX 
BX 
CX 
DX 




Data 
Memory 



0(PP P P^ 

Q Q Q O DS 

R R R R P 



R R R R P 



5-47 



In the illustration above, RRRRP represents a five hexadecimal digit data nnennory address — the actual location that is 
addressed. This address is the sum of QQQQO, the DS Segment register contents, and PPPP, the operand address. The 
LEA instruction loads the operand address PPPP into the identified 16-bit register. 

The LES instruction serves primarily to initialize the address register for string operations. As discussed earlier in this 
chapter, string instructions access the extra segment via the Dl and SI Index registers. 

The XLAT instruction is designed for table looi<-ups. An obvious application for an XLAT instruction would be to 
convert between ASCII and EBCDIC character codes. EBCDIC character codes being input could be translated into 
ASCII character codes, prior to being stored in memory, via the following instruction sequence: 

LABEL 



IN 


P0RT5 


Input an EBCDIC code 


XLAT 




Convert to ASCII 


STOB 


AL 


Store in mennory 


LOOP 


LABEL 


Return for next byte if there is one 



The instruction sequence above inputs character codes from I/O Port 5. These are assumed to be EBCDIC codes which 
arrive at the AL register. The XLAT instruction uses each EBCDIC code as an index into a conversion table whose base 
address is assumed held in the BX register Part of this conversion table may be illustrated as follows: 

Memory 



[BX]+ [DS]- 



■*- PPPPP 





1 


PPPPP+81 


6 1 


PPPPP + 82 


6 2 


PPPPP + 83 


6 3 


PPPPP + 84 


6 4 


PPPPP + 85 


6 5 


PPPPP +86 


6 6 


PPPPP + 87 


6 7 


PPPPP + 88 


6 8 


PPPPP + 89 


6 9 


PPPPP + 8A 




PPPPP + 88 




PPPPP + 80 




PPPPP + 8D 




PPPPP + 8E 




PPPPP + 8F 




PPPPP + 90 




PPPPP + gfi 


6 A 



EBCDIC character 
codes 



f 



These bytes not used by the table, 
can be used in other ways 



Equivalent ASCI I character codes 



After the XLAT instruction has executed, the ASCII version of the input EBCDIC code will be in the AL register. The 
STOB instruction stores this ASCII code in the Extra Segment memory location addressed by the Dl register; the Dl 
register contents are then incremented so that on the next pass of the iterative loop it addresses the next free memory 
byte in the Extra Segment table. 

The LOOP instruction decrements the CX register and branches back to the IN instruction if the CX register contents 
are not zero. 
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Secondary memory reference instructions occur in four versions. Each instruction may access a memory byte or a 
memory word; in either case, the result of the operation may be returned to a register, or to the memory word from 
which one operand was fetched. 

Note carefully that the Subtract instruction inverts the Carry status. 

The following numeric options are available with Add, Subtract, Multiply, and Divide instructions: 



Operation 


Unsigned Binary 


Signed Binary 


Paci<ed Decimal 


Unpaclted Decimal 1 


8-bit 


16-bit 


8-bit 


16-bit 


2 digit 


4 digit 


1 digit 


2 digit 


Add 


X 


X 


X 


X 


X 




X 




Subtract 


X 


X 


X 


X 


X 




X 




Multiply 


X 


X 


X 


X 






X 




Divide 


X 


X 


X 


X 






X 





Let us first look at addition and subtraction. 

Little needs to be said about signed and unsigned binary addition or subtraction; these are standard operations de- 
scribed in Volume 1. The only point to note is that the 8086 Subtract instructions invert the Carry status. 

Packed binary coded decimal (BCD) addition and subtraction are also quite standard in that 
they closely follow the logic described in Volume 1 . However, like the 8080A, the 8086 
uses Decimal Adjust instructions to handle packed binary coded decimal data. 

When you add two packed binary coded decimal numbers, it is assumed that the two numbers are indeed valid packed 
binary coded decimal data. The sum, which will not initially be a valid packed binary coded decimal number, is con- 
verted into one by the DAA instruction. This may be illustrated as follows: 



8086 BCD 
ADDITION 



ADD AL, BL 
DAA 



Add BCD data in BL to AL 
Decimal adjust result 



Note that you can only add bytes, and AL must be the destination when adding packed BCD data. 
Using abbreviations of Table 5-4. DAA instruction logic may be summarized as follows: 

If (AL) AND 0Fi6 is greater than 09-[q. or If (AF) = 1, then: 

(AL) — (AL) -I- 06i6 

(AF) - 1 
If (AL) is greater than 9Fi5 or if (CF) = 1. then: 

(AL) — (AL) -1-60 16 

(CF) - 1 

If one of the numbers being added is not a valid packed binary coded decimal number, then no error indication is given, 
but the answer will be wrong. For exarhple, there is nothing to stop you from adding IF-15 to A3i6 and then executing 
the DAA instruction to modify the sum; however, the result will be meaningless. 

When you subtract packed binary coded decimal numbers, once again it is assumed that the 
subtrahend and minuend are both valid packed binary coded decimal numbers. The difference 
will initially be meaningless; however, executing the DAS instruction generates a valid packed 
binary coded decimal result. This may be illustrated as follows: 

SBB AL BL 
DAS 



8086 BCD 
SUBTRACT 



5-49 



Once again you must subtract bytes, and the difference must be returned to the AL register. 
Using abbreviations of Table 5-4. DAS instruction logic may be summarized as follows: 

If (AL) AND OFie is greater than 09i6. or (AF) = 1, then: 
(AL) ^(AL) -O616 
(AF) - 1 

If (AL) Is greater than 9Fig, or (CF) = 1, then: 
(AL) — (AL) -6O16 
(CF) - 1 

When you subtract packed binary coded decimal numbers and generate a negative result, the Carry status will be (as 
is the case for binary subtraction) but the numeric negative difference will be a tens complement number rather than a 
twos complement number. Refer to Volume 1 for details. 

You can also add and subtract unpacked binary coded decimal numbers. These numbers may occupy the low-order 
four bits of a byte, leaving the high-order four bits empty: 





through 
10 1 

Or you may add and subtract ASCII characters. An ASCII character contains the binary coded decimal digit in low-order 
four bits and 001 1 in the high-order four bits. 

When you add unpacked binary coded decimal (BCD) digits, it is assumed that the two numbers being added are in- 
deed valid ASCII characters or unpacked BCD digits. The sum is initially meaningless; however, after executing 
the AAA instruction it is converted into one or two valid unpacked binary coded decimal digits. Note carefully 
that the AAA instruction does not generate ASCII characters; it generates one binary coded decimal digit per byte — 
which the four high-order bits zero. AAA instruction operations may be illustrated as follows: 

If (AL) AND OF-15 is greater than 09i5 or (AF) = 1. then: 
(AL) — (AL) + O616 
(AH) — (AH) -F 1 
(AF) - 1 



Unconditionally: 

(AL) ^ (AL) AND OF-\q 
(CF) - (AF) 

Note that AH is incremented if the sum in AX is more than 09i6. since 09i6 is the highest one-byte unpacked BCD 
value that is legal. 

When you subtract unpacked binary coded decimal numbers, you can subtract ASCII characters or bytes which 
have the four high-order bits blank. It makes no difference which option you choose; if you subtract two ASCII 
characters you will cancel out the four high-order bits — which are identical anyway. 

Assunning that the subtrahend and minuend are initially valid unpacked binary coded decimal numbers, the difference, 
which initially is meaningless, will be converted into one or two valid unpacked binary coded decimal digits by execut- 
ing the AAS instruction. This may be illustrated as follows: 



SUB 
AAS 



AL, BL 
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AAS instruction operations may be summarized as follows: 



If (AU AND OF-15 is greater than 09i6 or (AF) = 1 then: 
(AD — (AL) - 6 
(AH) — (AH) - 1 
(AF) - 1 



Unconditionally: 
(CF) - (AF) 
(AL) ^(AL) AND OF-^q 



8086 BCD 
MULTIPLICATION 



If you generate a negative result when subtracting unpacked binary coded decimal numbers, the Carry status will be 
zero and the answer will be in its tens complement form. 

You can multiply unpacked binary coded decimal numbers, but not packed binary coded 
decimal numbers. The multiplier and multiplicand must each be one byte long, with a single 
binary coded decimal digit in the low-order four bits and 0000 in the high-order four bits. Con- 
sider the multiplication 7x8 = 56io- The instruction sequence: 

MUL AL. BL 
A AM 

results in these register contents' changes: 



Before 



AX 



After 












7 


AL 
BL 


AX 





5 





6 


AL 









8 









8 


BL 



Assuming that the multiplier and multiplicand are valid, as illustrated above, the product will initially be meaningless. 
However, after executing the AAM instruction, a valid two-digit product will be generated, with the high-order digit in 
the AH register and the low-order digit in the AL register. 

AAIVI instruction logic is, in fact, quite simple. It may be illustrated as follows: 

(AH) ^ (AL) OA-15 (/ means "divided by") 
(AL) ^ (AL) modulo OAi 6 

Consider again 7x8 = 56io- This is initially computed as 7 x 8 = 38-\q: therefore, AH contains 00 and AL contains 
38 — before the AAM instruction is executed. 

(AL)/0Ai6 = 5 

Therefore, 05 is loaded into AH. "Modulo" is the remainder after division; therefore (AL) modulo OAig is the remainder 
following (AL)/OA-\q: it is 6, which is loaded into AL. 

Binary coded decimal multiplication does not take sign into account. It is up to your program logic to keep track of the 
sign. 

Binary coded decimal division, like multiplication, works only with unpacked binary coded 
decimal data. However, you must execute the AAD instruction before the DIV instruction in order 
to generate a valid unpacked binary coded decimal answer. This may be illustrated as follows: 



8086 BCD 
DIVISION 



ADD 
DIV AX. BL 

The AAD instruction takes the dividend, which we assume to be a valid unpacked binary coded decimal number in 
the AX register, and packs it into the AL register as follows: 

(AL) — (AH) *0Ai6+ (AL) 
(AH) — 

Consider the reverse of our multiplication examples: 

56/8 = 7 
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Initially, AH contains 05 and AL contains 06. After the AAD instruction is executed, AL contains: 

05i6*0Ai6 + O616 

which is 38i6- Now the DIV instruction can perform a pure binary division. 

The 8086 allows you to shift and rotate the contents of memory bytes or words. This is very useful since it allows 
counters and masks to be held in memory, rather than in CPU registers as is the usual case. 

Immediate instructions allow immediate data to be loaded into registers or memory locations. When loading im- 
mediate data into memory locations, you can generate 3, 4, 5, or 6 byte instruction object codes, depending on the 
length of the immediate data and the addressing options. See Table 5-5 for details. 

The Loop instructions are, in fact, variations of the multi-byte, string-handling 8086 capability. These instructions allow 
you to set up a counter in the CX register, which is decremented in order to identify the number of iterations for an in- 
struction loop. This may be illustrated as follows for the 8080A and the 8086: 

8O8OA 8086 

MVI C, COUNT MOV CX, DATA ■<- Initialize counter 

NEXT 

Repeated instructions 



OCR C LOOP NEXT ■«- Count and loop logic 

JNZ NEXT 

Jump-on-Condition instructions are limited in that they all provide an 8-bit signed binary displacement. Thus, you are 
limited to jumping within a 256-byte program relative memory page. 

Jump-on-Condition instructions are confusing at the best of times, because status combinations determine whether a 
jump will or will not occur. This is not very interesting information to you as a programmer. It is much easier to jump 
based on signed and unsigned binary numbers being less than, greater than, or equal to each other. Table 5-2 
therefore summarizes the way in which you should use 8086 Jump-on-Condition instructions. This table is similar 
to the table on page 7-32 of Volume 1 : however, the Carry status is inverted, since the 8086 Subtract instruction in- 
verts the Carry status. 

The way the 8086 creates Block Transfer and Search instructions is interesting. You begin with a set of instruc- 
tions, each of which performs a single operation. Each of these instructions can be made to repeat some number 
of times by preceding the instruction with a repeat (REP). 
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Table 5-2. 8086 Branch-on-Condition Instructions 



Branch Condition 


Status Conditions 


8086 Instruction 1 


Unsigned branch on less than or equal 

Unsigned branch on less 

Unsigned branch on equal 

Unsigned branch on not equal 

Unsigned branch on greater 

Unsigned branch on greater than or equal 

Signed branch on less than or equal 

Signed branch on less 

Signed branch on equal 

Signed branch on not equal 

Signed branch on greater 

Signed branch on greater than or equal 


C = 1 or Z = 1 

C = 1 

Z = 1 

Z = 

C = or Z = 

C=0 

Z = 1 or S XOR = 1 

S XOR = 1 

Z = 1 

Z=0 

Z = or S XOR = 

S XOR = 


JBE, JNA 
JB, JNAE 
JE, JZ 
JNE, JNZ 
JA, JNBE 
JAE, JNB 
JLE, JNG 
JL, JNGE 
JE, JZ 
JNE, JNZ 
JG, JNLE 
JGE, JNL 


These are general status 
test branch instructions 


Branch on counter decrement to zero 

Branch on no overflow 

Branch on overflow 

Branch on even parity 

Branch on odd parity 

Branch on positive 

Branch on negative 


= 
= 1 
P = 1 
P = 
S = 
S = 1 


JCXZ 

JNG 

JO 

JP, JPE 

JNP, JPO 

JNS 

JS 


These instructions to be used 
after a subtract or compare 



The way the 8086 creates Block Transfer and Search instructions is interesting. You begin with a set of instruc- 
tions, each of which performs a single operation. Each of these instructions can be made to repeat some number 
of times by preceding the instruction with a repeat (REP). For example, the MOVW instruction, executed on its 
own, will move one 16-bit word of data from a source memory location to a destination memory location, using Data 
Segment and Extra Segment addressing as follows: 



DS 


L 


L 


L 


L 


ES 


M 


M 


M 


M 












SI 


P 


P 


P 


P 


Dl 


Q 


Q 


Q 


Q 



M M M M 




Memory 



-»-L L L L 



MMMMO+QQQO 



Origin of extra segment 
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But, precede this instruction with a repeat and you move an entire block of data. This may be illustrated as follows: 

I Memory 
•-L L L L '~ 



Origin of extra segment 



DS 


L 


L 


L 


L 


ES 


M 


IVI 


M 


M 












SI 


P 


P 


P 


P 


Dl 


Q 


Q 


Q 


Q 












CX 


N 


N 


N 


N 



M 



LLLLO + PPPP 




LLLLO + PPPP 
+ N N N N 



MM MM 0+QQQQ 



MMMMO+QQQQ 
•- + N N N N 




When a Block Transfer or Search instruction is executed, the Program Counter contains the address of the prior 
instruction until it and the Block Transfer or Search instruction has completed executing. For example, when the 
REP and MOVS instruction pair executes, the Program Counter keeps pointing to the REP instruction as follows: 

REP <— PC points here until end of block move 
MOVS 

Only after the MOVS instruction has executed the number of times specified by the repeat will the Program Counter 
advance to the instruction following MOVS. This little piece of logic is designed to protect repeat instructions dur- 
ing interrupts. Interrupts are not locked out for the duration of a repeat instruction's execution: that would create in- 
tolerable delays between an interrupt request and acknowledge. Providing interrupts are enabled, an interrupt request 
can be acknowledged at any time during a repeat loop. Within the interrupt service routine, it is only necessary that 
you save the contents of the SI, Dl, and CX registers in order to preserve the repeat loop logic. When you return from 
the interrupt, the Program Counter is pointing the REP instruction that picks up where it left off, using the restored con- 
tents of the SI, Dl, and CX registers. 

A problem arises if you precede a Block Transfer or Search instruction with more than one prefix. Suppose, for 
example, you have a LOCK and a REP instruction preceding a MOV: 

REP 

LOCK 

MOVS 
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The LOCK must directly precede MOVS; otherwise, it would protect REP against a Hold. 

The Program Counter points to the LOCK instruction, not the REP instruction, while the MOVS repeatedly executes the 
specified number of times. If at some point an interrupt request is acicnowledged, then after the interrupt service 
routine completes execution you will return to the LOCK instruction, not the REP. This will cause the MOVS instruc- 
tion to be executed once more, rather than the number of times remaining in the repeat loop, as specified by the 
CX register contents and the REP instruction. Thus, if both prefixes must be used, interrupts should be disabled. 
However, you could still run into trouble with a nonmaskable interrupt. 

8086 - 8080A INSTRUCTION COMPATIBILITY 

As we have already stated, the 8086 instruction set is upward compatible with the 8080A at the source pro- 
gram level. That is, every 8080A instruction can be converted to one or more 8086 instructions. Table 5-6 
identifies the source program conversions recommeded by Intel. These are by no means the only conversions 
which are possible, but they are the ones you should use. since they are the ones that Intel plans to support. 

THE BENCHMARK PROGRAM 

The 8086 makes short work of our Benchmark program, which is well suited to the 8086 block transfer instruction. 
We assume that the I/O buffer and the table being filled both lie within single 65,536-byte program segments. The dis- 
placement to the beginning of the I/O buffer is loaded into the SI Index register, while the displacement to the first free 
byte of the data table is loaded into the Dl Index register. Our Benchmark program now consists of these few in- 
structions: 

Load I/O Buffer base address displacement in SI 

Load Data table starting address in ES and displacement to first free byte In Dl 

Load word count Into CX 

Move the data block 

Return new address of first free table byte 



LDS 


SI.IOBUF 


LES 


DI.ADDR 


MOV 


CX. COUNT 


REP 




MOVSW 




MOV 


ADDR, Dl 



5-55 



Table 5-3. 8086 Memory Addressing Options Identified by the EA Abbreviations 
in Tables 5-4, 5-5, and 5-6 



Memory 
Reference 


Segment 
Register 


Base 
Register 


Index 
Register 


Possible Displacements 


Assembly 
Language 
Operand 

Mnemonic 


16-Bit 
Unsigned 


8-Bit 

High-order Bit 

Extended 


None 


Normal Data 
Memory 
Reference 


OS 

(Altef<mt«i* 

GS,iS§oreS)' 


None 


SI 


X 


X 


X 




Dl 


'X 


X 


X 




ex 


SI 


X 


X' ' , 


X 




Pt 


X 


'' 'X 


X 




None 


X 


X 


X 




,., OS-; 


None 


Non« 


,X; -, 








'.;- 'ss.- , . 

(Att6rn«te/ 
CS,DSo!f^ES) 


BP 


, SI; 


X 


X 


X 




DJ 


X 


X 


X 




None 


X 


X 






Stack 


ss 


SP 


None 










String 
Data 


DS 


None 


SI 










ES 


None 


01 










Instruction 
Fetch 


CS 


PC 


None 










Branch 


CS 


PC 


None 




X 






I/O Data 


DS 


DX 


None 














These columns contribute to OEA. 


This column 
to be provided 


These columns contribute to EA. 




haded rows aptp 
haded row appli 


y to EA and DADDR. * The segment override allows DS or SS to be replaced 

by one of the other segment registers 

9S to EA and LABEL. X These are displacements that can be used to compute 


1^ s 




HZ = 








memory aaoresses. 
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The following abbreviations are used in Tables 5-4 and 5-5: 



AH 

AL 

AL7 

AX 

AX15 

BD 

BH 

BL 

BRANCH 

BS 

BX 

C 

CH 

CL 

CS 

CX 

DADDR 

DATA8 

DATA 16 

DH 

Dl 

DISP 

DISP8 

DL 

DS 

DX 

EA 

ES 

I 

l/D 

LABEL 

N 

O 

OEA 

PC 

PDX 

PORT 

RB 

RBD 

RBS 

RW 

RWD 

RWS 

SEGM 

SFR 

SI 

SP 

SR 

SS 



Accumulator, high-order byte 

Accumulator, low-order byte 

The value of register AL high-order bit (0 or 1) extended to a byte (OOig or fF-\Q) 

Accumulator, both bytes 

The value of register AH high-order bit (0 or 1) extended to a 16-bit word (OOOOis or FFFF16) 

The destination is a byte operand (used only by the Assembler) 

B register, high-order byte 

B register, low-order byte 

Program memory direct address, used in Branch addressing option shown in Tables 5-1 and 5-2 

The source is a byte operand (used only by the Assembler) 

B register, both bytes 

Carry status 

C register, high-order byte 

C register, low-order byte 

Code Segment register 

C register, both bytes 

Data memory address operands identified in Table 5-3 

Eight bits of immediate data 

16 bits of immediate data 

D register, high-order byte 

Destination Index register 

An 8-bit or 16-bit signed displacement 

An 8-bit signed displacement 

D register, low-order byte 

Data Segment register 

D register, both bytes 

Effective data memory address using any of the memory addressing options identified in Table 5-2 

Extra Segment register 

Status flag set to 1 

Increment/decrement selector for string operations; increment if D is 0, decrement if D is 1 

Direct data memory address, as identified in Table 5-2 

A number between and 7 

Status flag reset to 

Offset data memory address used to compute EA: 

EA =OEA-l- [DS] ♦ 16 
Program Counter 

I/O port addressed by DX register contents; port number can range from through 65,536 
A label identifying an I/O port number in the range through 255io 
Any one of the eight byte registers: AH, AL, BH. BL, CH, CL, DH, or DL 
Any RB register as a destination 
Any RB register as a source 

Any one of the eight 16-bit registers: AX, BX, CX, DX, SP, BP, SI, or Dl 
Any RW register as a destination 
Any RW register as a source 

Label identifying a 16-bit value loaded into the CS Segment register to execute a segment jump 
Status Flags register 
Source Index register 
Stack Pointer 

Any one of the Segment registers CS, DS, ES, or SS 
Stack Segment register 
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U Status flag modified, but undefined 

V Any nunnber in the range through 255io 

X Status flag modified to reflect result 

WD The destination is a word operand (used only by the Assembler) 

WS The source is a word operand (used only by the Assembler) 

[[]] Contents of the memory location addressed by the contents of the location enclosed in the double 

brackets 

[ ] The contents of the location enclosed in the brackets 

"— Data on the right-hand side of the arrow is moved to the location on the left-hand side of the arrow 

" — - Contents of locations on each side of " — <■ are exchanged 

— The twos complement of the value under the — 

^ Not equal to 

INSTRUCTION EXECUTION TIMES AND CODES 

Table 5-5 lists instructions in alphabetical order, showing object codes and execution times, for the 8086 and the 
8088, expressed in whole clock cycles. Execution time is the time required from beginning execution of an instruction 
that is in the queue to beginning execution of the next instruction in the queue. The time required to place an instruc- 
tion from memory into the queue (instruction fetch time) is not shown in the table; because of queuing, instruction 
fetch time occurs concurrently with instruction execution time and thus has no effect on overall timing, except as 
specifically noted in the table. 

Instruction object codes are represented as two hexadecimal digits for instruction bytes without variations. 

Instruction object codes are represented as eight binary digits for instruction bytes with variations for the instruction. 

The following notation is used in Tables 5-4 and 5-5: 

[] indicate an optional object code byte 

a one bit choosing length: 

in bit position a=0 specifies 1 data byte; a=1 specifies 2 data bytes 
in bit position 1 a=0 specifies 2 data bytes: a=1 specifies 1 data byte 
aa two bits choosing address length: 

no DISP = 00 
one DISP byte = 01 
two DISP bytes = 10, or 00 with bbb = 1 10 

11 causes bbb to select a register, using the 3-bit code given below for reg. 
bbb three bits choosing addressing mode: 

000 EA = (BX) -I- (SI) -f- DISP 

001 EA = (BX) -I- (Dl) -I- DISP 
010 EA = (BP) -I- (SI) -I- DISP 
Oil EA = (BP) -I- (Dl) -f- DISP 

100 EA = (SI) + DISP 

101 EA = (Dl) -I- DISP 

110 EA = (BP) -I- DISP 

111 EA = (BX) + DISP 

DISP represents two hexadecimal digit memory displacement 

ddd represents three binary digits identifying a destination register (see reg.) 

rr two binary digits identifying a segment register: 

00 = ES 

01 =CS 

10 = SS 

11 = DS 

reg three binary digits identifying a register: 





16-bit 


8-bit 


000 = 


AX 


AL 


001 = 


CX 


CL 


010 = 


DX 


DL 


oil = 


BX 


BL 


100 = 


SP 


AH 


101 = 


BP 


CH 


110 = 


SI 


DH 


111 = 


Dl 


BH 
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sss 
PPQQ 

V 



X 

YY 
YYYY 

z 



represents three binary digits identifying a source register (see reg) 
represents four hexadecimal digit memory address 
one bit choosing shift length: 

count = 1 

1 count = (CL) 
"don't care" bit 

represents two hexadecimal data digits 

represents four hexadecimal data digits 

one bit where z XOR (ZF) = 1 terminates loop 

Execution time is less than or equal to instruction fetch time. 

Includes up to eight clock cycles of overhead on each transfer due to queue maintenance. For conditional 

jumps, the lesser figure is when the test fails (no jump taken). 



Effective Address calculation and extra clock cycles: 



Extra Clock Periods | 


bbb 


EA 


8086(1) 


8088(2) 


000 


(BX) + (SI) 


7 


7 


000 


(BX) + (SI) + DISP8 


11 


11 


000 


(BX) + (SI) + DISP16 


11 


15 


001 


(BX) + (Dl) 


8 


8 


001 


(BX) + (Dl) + DISPB 


12 


12 


001 


(BX) + (Dl) + DISP16 


12 


16 


010 


(BP) + (SI) 


8 


8 


010 


(BP) + (SI) + DISP8 


12 


12 


010 


(BP) + (SI) + DISP16 


12 


16 


Oil 


(BP) + (Dl) 


7 


7 


Oil 


(BP) + (Dl) + DISP8 


11 


11 


Oil 


(BP) + (Dl) + DISP16 


11 


15 


100 


(SI) ir (Dl) or (BD) 


5 


5 


101 


or (BX) 






110 


+ DISP8 


9 


9 


111 


+ DISP16 


9 


13 




8-bJt immediate 


6 


6 




1 6-bit immediate 


6 


10 


(1) Add another 4 clock cycles for each 






1 6-bit operand or an odd address boundary. 






(2) Add anoter 4 clock cycles for each 






1 6-bit operand. 






Substitute the clock cycles shown above wherever EA appears 


in Tables 5-4 


and 5-5. 
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Table 5-4. A Summary of 8086 and 8088 Instructions 



i 
^ 


Mnemonic 


Operand (s) 


Object Code 


Clock Cycles 


Statuses 


Operation Performed 





D 


1 


T 


S 


z 


A 


P 


C 


5 


IN 
IN 

IN 

IN 

OUT 
OUT 

OUT 

OUT 


ALPORT 
AL,[DX] 

AX.PORT 

AX.lDXl 

ALPORT 
AL,[DX] 

AX.PORT 

AX,[DX] 


E4YY 
EC 1 

E5 YY 

ED 

E6 YY 

EE 1 

E7 YY 
EF 


10 
8 

10 

8 

10 
8 

10 

8 




















[AL] — [PORT] 

Load one byte of data from I/O port PORT into AL 
[AL] - [PDX] 

Load Into AL one byte of data from I/O port whose address is held in the DX 

register 
[AL] - [PORT], [AH] - [PORT+ 1 ] 

Load 1 6 bits of data into AX, AL receives data from I/O port PORT, AH 

receives data from I/O port PORT+ 1 
[AL] — [PDX], [AH] — [PDX+ 1 ] 

Load 1 6 bits of data into AX, AL receives data from I/O port whose address Is 

held in the DX register. AH receives data from the I/O port whose address is 

one higher 
[PORT] — [AL] 

Output one byte of data from register AL to I/O port PORT 
[PDX] *- [AL] 

Output one byte of data from register AL to the I/O port whose address is held 

in the DX register 
[PORT] - [AL], [PORT+1] - [AH] 

Output 1 6 bits of data. The AL register contents are output to I/O port PORT. 

The AH register contents are output to I/O port PORT+ 1 
[PORT] — [PDX], [PORT+1] — [PDX+1] 

Output 1 6 bits of data. The AL register contents are output tb the I/O port 

whose address is held in the DX register. The AH register contents is output 

to the I/O port whose address is one higher 


« 

1 
« 

E 

« 

>■ 
a. 


LDS 

LEA 
LES 

MOV 


RW.DADDR 

RW.DADDR 
RW.DADDR 

RB.DADDR 


C5 aasssbbb 
[DISP][DISP1 

8D aasssbbb 
[DISPKDISP] 

C4 aasssbbb 
[DISPKDISP] 

8A aadddbbb 
[DISPKDISP] 


16+EA 

2+EA 
16+EA 

8+EA 




















[RWl — [EA], [DS] — [EA+2] 

Load 16 bits of data from the memory word addressed by DADDR into 

register RW. Load 1 6 bits of data from the next sequential memory word into 

the DS register 
[RW] — OEA 

Load into RW the 1 6-bit address displacement which, when added to the 

segment register contents, creates the effective data memory address 
[RW] — [EA], [ES] ^ [EA+2] 

Load 16 bits of data from the memory word addressed by DADDR into 

register RW. Load 1 6 bits of data from the next sequential memory word into 

the ES register 
[RBj - [EA] 

Load one byte of data from the data memory location addressed by DADDR to 

register RB 











Table 5-4. A Summary of 8086 and 8088 Instructions (Continued) 


& 


Mnemonic 


Operand(s) 


Object Code 


Clock Cycles 


Statuses 


Operation Performed 


> 


D 


. 














t- 










1 


T: 


S; 


z 


A 


P 


C 






MOV 


RW.DADDR 


BBaadddbbb 
[DISPKDISP] 


8+EA 




















[RW] — [EAl 
Load 1 6 bits of data from the data memory word addressed by DADDR to 
register RW 




MOV 


DADDR.RB 


88 aasssbbb 
[DISP][DISP] 


9+EA 




















[EA] - [RB] 
Store the data byte from register RB in the memory byte addressed by DADDR 




MOV 


DADDR.RW 


89 aasssbbb 
[DISP][DISP] 


9-l-EA 




















[EA]-[RW] 
Store the 1 6-bit data word from register RW in the memory word addressed 
by DADDR 




MOV 


AL.LABEL 


AO PPQQ 


10 




















[AL] - lEA] 
Load the data memory byte directly addressed by LABEL into register AL 




MOV 


AX,LABEL 


A1 PPQQ 


10 




















[AX] *- lEA] 

Load the 1 6-bit data memory word directly addressed by LABEL into register 

AX 
[EA] - tAL] 


"S 


MOV 


LABEL,AL 


A2 PPQQ 


10 




















S 




























Store the 8-bit contents of register AL into the data memory byte directly ad- 


c 




























dressed by LABEL 


o 
u 


MOV 


LABEL.AX 


A3 PPQQ 


10 




















[EA] - [AX] 


« 




























Store the 1 6-bit contents of register AX into the data memory word directly 






























addressed by LABEL 


5 


MOV 


SR.DADDR 


8E aaOrrbbb 


8+EA 




















[SR] - [EA] 


i 






[DISP][DISP] 






















Load into Segment register SR the contents of the 1 6-bit memory word ad- 


> 




























dressed by DADDR 


o 

E 

e 

> 


MOV 


DADDR.SR 


8C aaOrrbbb 


9+EA 




















[EA] - [SR] 






[DISP][DISP] 






















Store the contents of Segment register SR in the 1 6-bit memory location ad- 




























dresed by DADDR 


"? 


XCHG 


RB.DADDR 


86 aaregbbb 


17+EA 




















[RB] ' — ► [EAJ 






[DISP][DISP1 






















Exchange a byte of data between register RB and the data memory location 


a. 


XCHG 
XLAT 


RW.DADDR 


87 aaregbbb 
[DISPKDISP] 

07 


17+EA 
11 




















addressed by DADDR 

[RW] < — ► [EA] 
Exchange 1 6 bits of data between register RW and the data memory location 
addressed by DADDR 

[AL] - [[AL] + [BX]] 
Load into AL the data byte stored in the memory location addressed by sum- 
ming initial AL contents with BX contents 











Table 5-4. A Sl 


mmary of 8086 and 8088 Instructions (Continued) 


• 


Mnemonic! 


Operand(s) 


Object Code 


Clock Cycles 


Statuses 


Operation Performed 






















1- 













D 


1 


T 


S 


z 


A 


p 


c 






ADC 


RB.DADDR^ 


1 2 aadddbbb 
[DISPIIDISP] 


9+EA 


X 








X 


X 


X 


X 


X 


[RBI — [EAl + [RBI + [CI 
Add the contents of the data byte addressed by DADDR. plus the Carry status, 
to register RB 




ADC 


RW.DADDR 


1 3 aadddbbb 
[DISP][DISP] 


9+EA 


X 








X 


X 


X 


X 


X 


[RW] - [EAl + [RWl + [CI 
Add the contents of the 1 6-bit data word addressed by DADDR. plus the Car- 
ry status, to register RW 




ADC 


DADDR.RB 


1 aasssbbb 
[DISP][DISP] 


16+EA 


X 








X 


X 


X 


X 


X 


[EAl - [EAl + [RB] + [CI 
Add the 8-bit contents of register RB, plus the Carry status, to the data 
memory byte addressed by DADDR 




ADC 


DADDR.RW 


1 1 aasssbbb 
(DISP][DISP] 


16+EA 


X 








X 


X 


X 


X 


X 


[EAl - [EAl + [RW] + [CI 
Add the 1 6-bit contents of register RW, plus the Carry status, to the data 


s 




























word addressed by DADDR 


2 


ADD 


RB.DADDR 


02 aadddbbb 


9+EA 


X 








X 


X 


X 


X 


X 


[RB] - [EA] + [RB] 


o. 
O 






[DISPKDISPl 






















Add the contents of the data byte addressed by DADDR to register RB 


2^ 


ADD 


RW.DADDR 


03 aadddbbb 


9+EA 


X 








X 


X 


X 


X 


X 


[RW] — [EAl + [RW] 


o 
E 






[DISP][DISP] 






















Add the contents of the 1 6-bit word addressed by DADDR to register RW 


a 

01 


ADD 


DADDR.RB 


00 aasssbbb 


16+EA 


X 








X 


X 


X 


X 


X 


[EAl - [EAl + [RB] 






[DISPKDISPl 






















Add the 8-bit contents of register RB to the data memory byte addressed by 


S 

c 




























DADDR 


1 


ADD 


DADDR.RW 


01 aasssbbb 


16+EA 


X 








X 


X 


X 


X 


X 


[EA] — [EA] + [RW] 


5 






[DISPKDISPl 






















Add the 1 6-bit contents of register RW to the data memory word addressed 


E 




























by DADDR 





AND 


RB.DADDR 


22 aadddbbb 


9+EA 











X 


X 


u 


X 





[RBI - [EAl AND [RB] 


« 






[DISP][DISP1 






















AND the 8-bit contents of register RB with the data memory byte addressed 


S 




























by DADDR. Store the result in RB 


2^ 


AND 


RW.DADDR 


23 aadddbbb 


9+EA 











X 


X 


u 


X 





[RW] ^ [EAl AND [RWl 


1 






[DISPKDISPl 






















AND the 1 6-bit contents of register RW with the data memory word ad- 


8 




























dressed by DADDR. Store the result in RW 


w 


AND 


DADDR.RB 


20 aasssbbb 
[DISPKDISPl 


16+EA 











X 


X 


u 


X 





[EA] - [EAl AND [RBl 
AND the 8-bit contents of register RB with the data memory byte addressed 
by DADDR. Store the result in the addressed data memory byte 




AND 


DADDR.RW 


21 aasssbbb 
[DISPKDISPl 


16+EA 











X 


X 


u 


X 





[EA] — [EA] AND [RWl 
AND the 1 6-bit contents of register RW with the data memory word ad- 
dressed by DADDR. Store the result in the addressed data memory word 




CMP 


RB.DADDR 


3A aadddbbb 
[DISPKDISPl 


9+EA 


X 








X 


X 


X 


X 

1 


X 


[RBI - [EA] 
Subtract the contents of the data memory byte addressed by DADDR from the 
contents of register RB. Discard the result, but adjust status flags 




CMP 


RW.DADDR 


3B aadddbbb 
[DISPKDISPl 


9+EA 


X 








X 


X 


X 


X 


X 


[RWl - [EAl 
Subtract the 1 6-bit contents of the data memory word addressed by DADDR 
from the contents of register RW. Discard the result, but adjust status flags 











Table 5-4. A Su 


Timarv 


Of 8086 


an 


d 8088 Instructions (Continued) 


o 










Statuses 




§: 


Mnemonic 


Operand(s) 


Object Code 


Clock Cycles 




Operation Performed 




















h- 













D 


1 


T 


S 


z 


A 


P 


c 






CMP 


DADDR.RB 


38 aasssbbb 
[DISP][DISP] 


9+EA 


T 








"x 


x" 


x" 


"x 


"x 


lEA] - IRBI 
Subtract the 8-bit contents of register RB from the data memory byte ad- 
dressed by DADDR. Discard the result, but adjust status flags 




CMP 


DADDR,RW 


39 aasssbbb 
[DISPllDISP] 


9+EA 


X 








X 


X 


X 


X 


X 


[EA] - [RW] 
Subtract the 1 6-bit contents of register RW from the data memory word ad- 
dressed by DADDR. Discard the result, but adjust status flags 




DEC 


DADDR 


1111111a 
aaOOIbbb 
[DISPKDISP] 


15+EA 


X 








X 


X 


X 


X 




[EA] — lEA] - 1 
Decrement the contents of the memory location addressed by DADDR. De- 
pending on the prior definition of DADDR, an 8-bit or a 1 6-bit memory loca- 


^g 




























tion may be decremented 


O 

3 


DIV 


AX.DADDR 


F6aa110bbb 


(86-96 )+EA 


u 








u 


u 


u 


u 


u 


[AX] — [AXl/lEA] 


C 






[DISP][DISP] 






















Divide the 1 6-bit contents of register AX by the 8-bit contents of the memory 


C 

o 
o 




























byte addressed by DADDR. Store the integer quotient In AL and the remainder 




























in AH. If the quotient is greater than FFi q, execute a "divide by 0" interrupt 


"5 


DIV 


DX.DADDR 


F7 aallObbb 


(150-168)+EA 


u 








u 


u 


u 


u 


u 


[DX] [AX] — [DX] [AXl/lEA] 


2 
e 






[DISPllDISP] 






















Divide the 32-bit contents of registers DX (high-order) and AX (low-order) by 


a 
O 




























the 1 6-bit contents of the memory word addressed by DADDR. Store the in- 






























teger quotient In AX and the remainder in DX. If the quotient is greater than 


1 




























FFFF15, execute a "divide by 0" interrupt 


• 


IDIV 


AX.DADDR 


F6aa111bbb 


(107-1 18)8+EA 


u 








u 


u 


u 


u 


u 


[AX] — [AX]/[EA] 






[DISP][DISP1 






















Divide the 1 6-bit contents of register AX by the 8-bit contents of the memory 


c 




























byte addressed by DADDR, treating both contents as signed binary numbers. 


£ 




























Store the quotient, as a signed binary number, in AL. Store the remainder, as 


• 




























an unsigned binary number, in AH. If the quotient is greater than 7F15, or less 


EC 




























than -80-16. execute a "divide by 0" interrupt 


s 


IDIV 


DX.DADDR 


F7aa111bbb 


(171)-190)+EA 


u 








u 


u 


u 


u 


u 


[DX] [AX] — [DX] [AX]/[EA] 


E 

9 






[DISP][DISP] 






















Divide the 32-bit contents of register DX (high-order) and AX (low-order) by 


s 




























the 1 6-bit contents of the memory word addressed by DADDR. Treat both 


> 

(0 




























contents as signed binary numbers. Store the quotient, as a signed binary 


•S 




























number, in AX. Store the remainder, as an unsigned binary number, in AH. If 


8 




























the quotient is greater than 7FFFi g, or less than -8000 1 5, execute a "divide 


m 




























by 0" interrupt 




IMUL 


AL.DADDR 


F6aa101bbb 
[DISPKDISP] 


(86-104)+EA 


X 








u 


u 


u 


u 


X' 


[AX] — [AL] . [EA] 
Multiply the 8-bit contents of register AL by the contents of the memory byte 
addressed by DADDR. Treat both numbers as signed binary numbers. Store 
the 1 6-bit product in AX 




IMUL 


AX.DADDR 


F7aa101bbb 
[DISPllDISP] 


(134-160)+EA 


X 








u 


u 


u 


u 


X 


[DX] [AX] - [AX] . [EA] 
Multiply the 1 6-bit contents of register AX by the 1 6-bit contents of the 
memory word addressed by DADDR. Treat both numbers as signed binary 
numbers. Store the 32-bit product in DX (high-order word) and AX (low-order 
word) 











Table 5-4. A Su 


mmary of 8086 and 8088 Instructions (Continued) 


i. 


Mnemonic 


Operand(s) 


Object Code 


Clock Cycles 


Statuses 


Operation Performed 


> 


D 




■ 












1- 










1 


T' 


S 


z 


A 


p 


C: 






INC 


DADDR 


1111111a 

aaOOObb 

[DISPKDISP] 


15+EA 


X 








X 


X 


X 


X 




[EA] - [EA] + 1 
Increment the contents of the memory location addressed by DADDR. De- 
pending on the prior definition of DADDR, an 8-bit or a 1 6-bit memory loca- 
tion may be incremented 




MUL 


AL.DADDR 


F6 aalOObbb 
[DISP][DISP] 


(76-83)+EA 


X 








u 


u 


u 


u 


X 


[AX] - [AL] . [EA] 
Multiply the 8-bit contents of register AL by the contents of the memory byte 
addressed by DADDR. Treat both numbers as unsigned binary numbers. Store 
the 1 6-bit product in AX 




MUL 


F7 


F7 aalOObbb 


(124-139)+EA 


X 








u 


u 


u 


u 


X 


[DX] [AX] — [AX] . [EA] 


^ 






[DISP][DISP] 






















Multiply the 1 6-bit contents of register AX by the 1 6-bit contents of the 


3 




























memory word addressed by DADDR. Treat both numbers as unsigned binary 


C 




























numbers. Store the 32-bit product in DX (high-order word) and AX (low-order 


o 
O 




























word) 


NEG 


DADDR 


1111011a 


16+EA 


X 








X 


X 


X 


X 


X 


[EA] - [EA] 


2 






aaOIIbb 






















Twos complement the contents of the addressed memory location. Depend- 


1 






[DISP][DISP] 






















ing on the prior definition of DADDR, an 8-bit or 1 6-bit memory location may 


o 




























be twos complemented 


^ 


NOT 


DADDR 


1111011a 


16+EA 




















[EA] — NOT [EA] 


E 






aaOIObbb 






















Ones complement the contents of the addressed memory location. Depending 


4) 






[DISPKDISP] 






















on the prior definition of DADDR, an 8-bit or 1 6-bit memory location may be 


• 




























ones complemented 


u 


OR 


RB.DADDR 


OA aadddbbb 


9+EA 


X 








X 


X 


u 


X 


X 


[RB] ^ [EA] OR [RB] 


1 






[DISP][OISP] 






















OR the 8-bit contents of register RB with the data memory byte addressed by 


i 




























DADDR. Store the result in RB 


£■ 


OR 


RW.DADDR 


OB aadddbbb 


9+EA 


X 








X 


X 


u 


X 


X 


[RW] - [EA] OR [RW] 








[DISPKDISP] 






















OR the 1 6-bit contents of register RW with the data memory word addressed 


• 




























by DADDR. Store the result in RW 


OR 


DADDR.RB 


08 aasssbbb 


16+EA 


X 








X 


X 


u 


X 


X 


[EA] — [EA] OR [RB] 






[DISP1[DISP] 






















OR the 8-bit contents of register RB with the data memory byte addressed by 


c 

o 




























DADDR. Store the result in the data memory byte 


s 


OR 


DADDR,RW 


09 aasssbbb 


16+EA 


X 








X 


X 


u 


X 


X 


[EA] — [EA] OR [RW] 


(0 






[DISP][DISP] 






















OR the 1 6-bit contents of register RW with the data memory word addressed 

by DADDR. 

Store the result in the data memory word 



Table 5-4. A Summary of 8086 and 8088 Instructions (Continued) 



Mnemonic 



Operand(s) 



Object Code 



Clock Cycles 



Statuses 



OlD I T S Z A P C 



Operation Performed 



RCL 



ROL 



DADDR,N 



DADDR.N 



RCR 



ROL 



DADDR.N 



DADDR.N 



llOIOOva 
aaOllbbb 
[DISPKDISP] 

nOIOOva 
aaOOObbb 



nOIOOva 
aaOOIbbb 
[DISPKDISP] 

nOIOOva 
aaOOObbb 
[DISP1[DISP] 



N=1 
15+EA; 
N>1 
4N+20+EA 



N=1 15+EA 



N>1 
4N+20+EA 



Rotate the contents of the data memory location addressed by DADDR left 
through the Carry status. If N = 1 , then rotate one bit position. If N =CL, then 
register CL contents provide the number of bit positions. Depending on prior 
definition, DADDR may address a byte: 



r-Ei*-[ 



[EA] 



h 



or DADDR may address a word: 

r-QHZZ 



[EA] 



q 



h 



[EA+1] 



h 



As RCL, but rotate right 



Rotate the contents of the data memory location addressed by DADDR left. 
Move the left most bit into the Carry status. If N = 1 , then rotate one bit posi- 
tion. If N = CL, then register CL contents provides the number of bit positions. 
Depending on prior definition, DADDR may address a byte: 



Eh-^ 



[EA] 



h 



or DADDR may address a word: 

Eh 



i 



[EA] 



q 



[EA+1] 



h 











Table 5-4. A Summary 


of 8086 and 8088 Instructions (Continued) 


1 


Mnemonic 


Operand(s) 


Object Code 


Clock Cycles 


Statuses 


Operation Performed 





D 


1 


T 


S 


z 


A 


p 


c 


1 

3 
C 

1 

o 

S 

(S 

a 

o 

1 

c 
o 

£ 
• 
• 

E 

• 

CO 
■D 

W 


SAL 

SAR 

SBB 
SBB 


DADDR.N 

DADDR.N 

RB,DADDR 
RW.DADDR 


llOIOOva 
aaOOIbbb 
[DISP][DISP] 

noioova 

aalllbbb 
[DISP][DISP] 

lAaadddbbb 
[DISPJIDISPI 

IBaadddbbb 
[DISPIIDISP] 


N=1 15+EA 

N=1 15+EA; 

N>1 

4N+20+EA 

9+EA 
9+EA 


X 

X 

X 
X 








X 

X 
X 


X 

X 
X 


u 

X 
X 


X 

X 
X 


X 

X 

X 
X 


As ROL, but rotate right 

Shift the contents of the data memory location addressed by DADDR left. 
Move the left most bit into the Carry status. If N = 1 , then shift one bit posi- 
tion. If N = CL, then register CL contents provides the number of bit positions. 
Depending on prior definition, DADDR may address a byte: 


fc"|-*— 1 [EA] |-*-0 
or DADDR may address a word: ' 


1 c 1^ [EA] t— 1 




« 1 [EA+1] \m-0 

As SAL, but shift right and propagate sign: 


-^ [EA] h- Hc| 
or 


-m^ [EA] 1 — 1 


L^ [EA+1] J_»»|T| 

[RB] - [RB] - [EA] - [C] 
Subtract the contents of the data byte addressed by DADDR from the con- 
tents of 8-bit register RB, using twos complement arithmetic. Decrement the 
result in RB if the Carry status was initially set 

[RWl - [RW] - [EAl - [C] 
Subtract the contents of the 1 6-bit data word addressed by DADDR from the 
contents of the 16-bit register RW, using twos complement arithmetic. 
Decrement the result in RW if the Carry status was initially set 











Table 5-4. A Summary 


of 8086 


and 8088 Instructions (Continued) 


«> 

a 


Mnemonic 


Operand(s) 


Object Code 


Clock Cycles 


Statuses 


Operation Performed 


> 




















1- 













D 


1 


T 


S 


z 


A 


p 


C 






SBB 


DADDR.RB 


1 8 aasssbbb 
[DISPKDISP] 


16+EA 


X 








X 


X 


X 


X 


X 


[EAl *- [EA] - [RB] - [C] 
Subtract the contents of 8-blt register RB from the data byte addressed by 
DADDR. using twos complement arithmetic. Decrement the result in data 
memory if the Carry status was initially set 




SBB 


DADDR.RW 


1 9 aasssbbb 
[DISP][DISP] 


16+EA 


X 








X 


X 


X 


X 


X 


[EA] - [EA] - [RW] - [C] 
Subtract the contents of 1 6-bit register RW from the 1 6-bit data word ad- 
dressed by DADDR. using twos complement arithmetic. Decrement the result 
in data memory if the Carry status was initially set 




SHL 


DADDR.N 






X 








X 


X 


u 


X 


X 


This is an alternate mnemonic for SAL 


1 


SHR 


DADDR.N 


llOIOOva 


N=1 15+EA; 


X 








X 


X 


u 


X 


X 


As SAL. but shift right: 


3 

c 
o 
O 

S 
« 

o 

1 

e 
o 

c 

s 


SUB 


RB.DADDR 


aaipibb 
IDISPllDISP] 

2A aadddbbb 


N>1 
4N+20+EA 

9+EA 


X 








X 


X 


X 


X 


X 




0-^ [EA] 1 fc^^ 

or 


0-m^ [EA] 1 — , 




L^ [EA+1] |-_fc^T] 


[RB] - [RB] - [EA] 








[DISP][DISP] 






















Subtract the contents of the data memory byte addressed by DADDR from the 


£■ 




























contents of 8-bit register RB, using twos complement arithmetic 


o 

E 


SUB 


RW.DADDR 


2B aadddbbb 


9+EA 


X 








X 


X 


X 


X 


X 


[RW] *- [RW] - [EA] 


e 






IDISPllDISP] 






















Subtract the contents of the 1 6-bit data memory word addressed by DADDR 


> 




























from the contents of 1 6-bit register RW. using twos complement arithmetic 




SUB 


DADDR.RB 


28 aasssbbb 


16+EA 


X 








X 


X 


X 


X 


X 


[EA] — [EA] - [RB] 


o 






[DISP][DISP] 






















Subtract the contents of 8-bit register RB from the data memory byte ad- 


o 
a 

(0 




























dressed by DADDR. using twos complement arithmetic 




SUB 


DADDR.RW 


29 aasssbbb 
[DISP][DISP] 


16+EA 


X 








X 


X 


X 


X 


X 


[EA] - [EA] - [RW] 
Subtract the contents of 1 6-bit register RW from the 1 6-bit data memory 
word addressed by DADDR, using twos complement arithmetic 




TEST 


DADDR.RB 


84 aaregbbb 
[DISP][DISP1 


9+EA 











X 


X 


u 


X 





[EA] AND [RB] 
AND the 8-bit contents of the data memory location addressed by DADDR 
with the contents of 8-bit register RB. Discard the result, but adjust status 
flags appropriately 



Table 5-4. A Summary of 8086 and 8088 Instructions (Continued) 



c 


Mnemonic 


Operand(s) 


Object Code 


Clock Cycles 


Statuses 


Operation Performed 





D 


1 


T 


S 


z 


A 


p 


c 


11 
11 

o O 
•1 

11 

o a 
SI 


TEST 

XOR 
XOR 
XOR 
XOR 


DADDR,RW 

RB.DADDR 
RW.DADDR 
DADDR.RB 
DADDR.RW 


85 aareg bbb 
[DISPJIDISP] 

32 aadddbbb 
[DISPKDISP] 

33 aadddbbb 
[DISP1[DISP] 

30 aasssbbb 
[DISP][DISP] 

31 aasssbbb 
[DISP1[DISP] 


9+EA 

9+EA 
9+EA 
16+EA 
16+EA 
















X 

X 
X 
X 
X 


X 

X 
X 
X 
X 


u 

u 
u 
u 
u 


X 

X 
X 
X 
X 










[EA] AND [RW] 
AND the 1 6-bit contents of the data memory word addressed by DADDR with 
the contents of 1 6-blt register RW. Discard the result, but adjust status flags 
appropriately 

[RB] ^ [RB] XOR [EA] 
Exclusive OR the 8-bit contents of register RB with the data memory byte ad- 
dressed by DADDR. Store the result in RB 

[RW] - [RW] XOR [EA] 
Exclusive OR the 1 6-bit contents of register RW with the 1 6-bit data memory 
word addressed by DADDR. Store the result in RW 

[EA] — [RB] XOR [EA] 
Exclusive OR the 8-bit contents of register RB with the data memory byte ad- 
dressed by DADDR. Store the result in the addressed data memory byte 

[EA] — [RW] XOR [EA] 
Exclusive OR the 1 6-bit contents of register RW with the data memory word 
addressed by DADDR. Store the result in the addressed data memory word 


• 
a 

1 
E 
JE 


MOV 

MOV 

MOV 
MOV 


DADDR, 
DATA8 

DADDR, 
DATA16 

RB,DATA8 

RW.DATAie 


C6 aaOOObbb 
[DISPJIDISP] YY 

C7 aaOOObbb 
[DISP][DISP1 YYYY 

lOIIOdddYY 

101 llddd YYYY 


10+EA 

10+EA 

4* 
4* 




















[EA] — DATA8 

Load the immediate data byte DATA8 into the data memory byte addressed 

by DADDR 
[EA] ^ DATA 16 

Load the immediate 16-bit data word DATA16 into the data memory word 

addressed by DADDR 
[RB] ^ DATA8 

Load the immediate data byte DATA8 into 8-bit register RB 
[RW] ^ DATA 16 

Load the immediate 16-bit data word DATA 16 into 16-bit register RW 


1 

3 
-> 


JMP 
JMP 

JMP 


BRANCH 

BRANCH, 
SEGM 

DADDR 


moioai 

DISP [DISP] 
EA PPQQ PPQQ 

FFaalOObbb 
IDISPIIDISP] 


15" 
15" 

18+EA" 




















[PC] ^ [PC] + DISP 
Jump direct to program memory location identified by label BRANCH. The 
displacement DISP which must be added to the Program Counter will be com- 
puted as an 8-bit or 1 6-bit signed binary number, as needed, by the assembler 

[PC] — DATA 16, [CSl — DATA 16 
Jump direct into a new segment. BRANCH is a label which becomes a 1 6-bit 
unsigned data value which is loaded into PC. SEGM is a label which becomes 
another 16-bit unsigned data value that is loaded into the CS segment 
register 

[PC] - [EA] 
Jump indirect in current segment. The 1 6Tbit contents of the data memory 
word addressed by DADDR is loaded into PC 
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mmarv 
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• 










Statuses 




a. 


Mnemonic 


Op«rand(s) 


Object Code 


Clock Cycles 




Operation Performed 


^ 





D 


1 


T 


S 


-z 


A 


P 


C 


"T" 


JMP 


DADDR.CS 


FFaalOlbbb 


24+EA" 




















[PCI ^ [EAl, [CS] - [EA+2] 


1 






[DISPKDISPl 






















Jump indirect into a new segment. The 1 6-bit contents of the data memory 


o 




























word addressed by DADDR is loaded into PC. The next sequential 1 6-bit data 


a 
e 




























memory word's contents is loaded into the CS segment register 


c 
-> 


JMP 


RW 


FF niOOreg 


11 




















[PC] ^ [RW] 
Jump to memory location whose address is contained in register RW. 




CALL 


BRANCH 


EB DISP DISP 


19" 




















[[SP]] - [PC], [SP] - [SP] -2, [PC] - [PC] + DISP 
Call a subroutine in the current program segment using direct addressing 




CALL 


BRANCH, 
SEGM 


9A PPQQ PPQQ 


2B" 




















[[SP]] — [CS], [SP] — [SP] -2, [[SP]] — [PC], [SP] — [SPl -2, [PC] — 

DATA1 6, 

[CS] — DATA 16 

Call a subroutine in another program segment using direct addressing. 

BRANCH and SEGM are labels that become different 1 6-bit data words; they 

are loaded into PC and CS, respectively 




CALL 


DADDR 


FFaaOIObbb 
[DISP][DISP] 


21+EA" 




















[[SP]] - [PC], [SP] - [SP] -2, [PC] - [EA] 
Call a subroutine in the current program segment using indirect addressing. 
The address of the subroutine called is stored in the 1 6-bit data memory 
word addressed by DADDR 


£ 


CALL 


DADDR.CS 


FFaaOllbbb 


37+EA" 




















[[SPJl - [CS], [SP] - [S2] -2, [[SP]] - [PC], [SP] - [SP] -2, [PC] - [EA], 


5 






[DISP][DISP1 






















[CS] — [EA+2] 


e 




























Call a subroutine in a different program segment using indirect addressing. 


e 

IS 




























The address of the subroutine called is stored in the 1 6-bit data memory 


a 




























word addressed by DADDR. The new CS register contents is stored in the 


O 




























next sequential program memory word 


1 


CALL 


RW 


FF llOIOreg 


16" 




















[SP] — [PC],[SP] — [SP-2], [PC] — [RW] 


3 




























Call a subroutine whose address is contained in register RW. 


^ 


RET 




C3 


B" 




















[PC] - [[SP]], [SP] - [SP] + 2 


3 
(0 


RET 
RET 

RET 


CS 
DATA 16 

CS,DATA16 


CB 
C2 YYYY 

CA YYYY 


12" 
17" 

18" 




















Return from a subroutine in the current segment 
[PCI - [[SP]], [SP] - [SP] +2, [CS] - [[SP]], [SP] - [SP] +2 

Return from a subroutine in another segment 
[PC] — [[SP]], [SP] — [SP] +2 +DATA16 
Return from a subroutine in the current segment and add an immediate dis- 
placement to SP 
[PC] — [[SP]], [SP] — [SP] +2, [CS] — [[SP]], [SP] «- [SP] +2 +DATA16 
Return from a subroutine in another segment and add an immediate displace- 
ment to SP 
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a 
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> 




















H 










O 


D 


1 


T 


S 


z. 


A 


p 









ADD 


AL,DATA8 


04 YY 


4* 


X 








X 


X 


X 


X 


X 


[AL] — [AL] + DATA8 
Add 8-bit immediate data to the AL register 




ADD 


AX,DATA16 


05 YYYY 


4* 


X 








X 


X 


X 


X 


X 


[AX] ^[AX] + DATA 16 
Add 1 6-bit immediate data to the AX register 




ADD 


RB,DATA8 


80 IIOOOdddYY 


4' 


X 








X 


X 


X 


X 


X 


[RB] — [RB] + DATA8 
Add 8-bit immediate data to the RB register 




ADD 


RW,DATA16 


81 llOOOddd 
YYYY 


4* 


X 








X 


X 


X 


X 


X 


[RW] ^[RW] + DATA16 
Add 1 6-bit immediate data to the RW register 




ADD 


DADDR, 
DATA8 


80 aaOOObbb 
[DISPIIDISPI YY 


17+EA 


X 








X 


X 


X 


X 


X 


[EA] *- [EAl + DATA8 
Add 8-bit immediate data to the data memory byte addressed by DADDR 




ADD 


DADDR, 
DATA 16 


81 aaOOObbb 
[DISP][DISP] YYYY 


17+EA 


X 








X 


X 


X 


X 


X 


[EA] — [EA] + DATA 16 
Add 16-bit immediate data to the data memory word addressed by DADDR 




ADC 


AL,DATA8 


14 YY 


4* 


X 








X 


X 


X 


X 


X 


[AL] — [AL] + DATA8 + [C] 
Add 8-bit immediate data, plus carry, to the AL register 




ADC 


AX,DATA16 


15 YYYY 


4* 


X 








X 


X 


X 


X 


X 


[AX] -[AX] + DATA 16 + [C] 
Add 1 6-bit immediate data, plus carry, to the AX register 


s 


ADC 


B,DATA8 


80 llOIOddd YY 


4* 


X 








X 


X 


X 


X 


X 


[RB] — [RB] + DATA8 + [C] 


s 




























Add 8-bit immediate data, plus carry, to the RB register 


o 

a. 


ADC 


RW,DATA16 


81 nolOddd 


4* 


X 








X 


X 


X 


X 


X 


[RW] — [RW] + DATA16 + [C] 


O 

« 






YYYY 






















Add 1 6-bit immediate data, plus carry, to the RW register 


.2 


ADC 


DADDR, 


80aa010bbb 


17+EA 


X 








X 


X 


X 


X 


X 


[EA] — [EA] + DATA8 + [C] 


» 




DATA8 


[DISP][DISP] YY 






















Add 8-bit immediate data, plus carry, to the data memory byte addressed by 


E 




























DADDR 




ADC 


DADDR, 
DATA 16 


81 aaOIObbb 
[DISPHDISPIYYYY 


17+EA 


X 








X 




X 


X 


X 


[EA] — [EA] + DATA16 + [C] 
Add 1 6-bit immediate data, plus carry, to the data memory word addressed 
by DADDR 




AND 


AL,DATA8 


24 YY 


4* 











X 


X 


u 


X 





[AL] «- [AL] AND DATA8 
AND 8-bit immediate data with AL register contents 




AND 


AX,DATA16 


25 YYYY 


4* 











X 


X 


u 


X 





[AX] — [AX] ANDDATA16 
AND 1 6-bit immediate data with AX register contents 




AND 


RB,DATA8 


80 inOOddd YY 


4* 











X 


X 


u 


X 





[RB] — [RB] AND DATA8 
AND 8-bit immediate data with RB register contents 




AND 


RW,DATA16 


81 niOOddd 
YYYY 


4* 











X 


X 


u 


X 





[RW] — [RW] AND DATA16 
AND 1 6-bit immediate data with RW register contents 




AND 


DADDR,8 


80aa100bbb 
[DISPJIDISPI YY 


17+EA 











X 


X 


u 


X 





[EA] — [EA] AND DATA8 
AND 8-bit immediate data with contents of data memory byte addressed by 
DADDR 




AND 


DADDR, 
DATA1 6 


81 aalOObbb 
[DISP][DISP] YYYY 


17+EA 











X 


X 


u 


X 





[EA] — [EA] ANDDATA16 
AND 1 6-bit immediate data with contents of 1 6-bit data memory word ad- 
dressed by DADDR 
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of 8086 


and 8088 Instructions (Continued) 


c 










Statuses 




a 


MnAmnniP' 


Operand(s). 


Object Code 


Clock Cycles 




Operation Performed 


^ 


IVIIIOIIIUillW 


O 


D 


1 


T 


S 


z 


A 


p 







CMP 


AL.DATAS 


3CYY 


4* 


X 








X 


X 


X 


X 


X 


[AL] - DATA8 
Subtract 8-bit immediate data from AL register contents. Discard result, but 
adjust status flags 




CMP 


AX,DATA16 


3D YYYY 


4" 


X 








X 


X 


X 


X 


X 


[AX] -DATA16 
Subtract 1 6-bit immediate data from AX register contents. Discard result, but 
adjust status flags 




CMP 


RB,DATA8 


80 liniddd YY 


4* 


X 








X 


X 


X 


X 


X 


[RB] - DATA8 
Subtract 8-bit immediate data from RB register contents. Discard result, but 
adjust status flags 




CMP 


RW,DATA16( 


1 00000a 1 
iniddd 
YY [YY] 


4* 


X 








X 


X 


X 


X 


X 


[RW] - DATA 16 
Subtract 1 6-bit immediate data from RW register contents. Discard result, 
but adjust status flags 




CMP 


DADDR, 
DATA8 


80aa111bbb 
[DISPIIDISP] YY 


10+EA 


X 








X 


X 


X 


X 


X 


[EA] - DATA8 
Subtract 8-bit immediate data from contents of data memory byte addressed 






























by DADDR. Discard result, but adjust status flags 


1 


CMP 


DADDR, 


1 00000a 1 


10+EA 


X 








X 


X 


X 


X 


X 


[EA] -DATA 16 


.1 




DATA 16 


aalllbbb 






















Subtract 1 6-bit immediate data from contents of 1 6-bit data memory word 


1 






[DISP)[DISP]YY|[YY] 






















addressed by DADDR. Discard result, but adjust status flags 


O 


OR 


AL.DATAB 


OCYY 


4* 











X 


X 


U 


X 





[AL] ^ [AL] OR DATA8 


• 

(0 




























OR 8-hit Immediate data with AL register contents 


S 
£ 


OR 


AX.DATAie 


OD YYYY 


4* 











X 


X 


u 


X 





[AX] —[AX] OR DATA 16 


o 




























OR 1 6-blt Immediate data with AX register contents 


« 


OR 


RB.DATAB 


80 llOOIddd YY 


4* 











X 


X 


u 


X 





[RB] — [RB] OR DATA8 


■■5 




























OR 8-blt Immediate data with RB register contents 


1 


OR 


RW,DATA16 


81 nOOIddd 


4* 











X 


X 


u 


X 





[RW] — [RW] OR DATA 1 6 


E 






YYYY 






















OR 1 6-bit immediate data with RW register contents 




OR 


DADDR, 
DATA8 


SOaaOOIbbb 
[DISPKDISPl YY 


17+EA 











X 


X 


u 


X 





[EA] — [EAl OR DATA 8 
OR 8-bit immediate ata with contents of data memory byte addressed by 
DADDR 




OR 


DADDR, 
DATA 16 


81 aaOOIbbb 

[DISPKDISP] 

YYYY 


17+EA 











X 


X 


u 


X 





[EA] — [EAJ0RDATA16 
OR 1 6-bit immediate data with contents of 1 6-bit data memory word ad- 
dressed by DADDR 




SBB 


AL.DATAS 


1C YY 


4* 


X 








X 


X 


X 


X 


X 


[AL] — [AL] - DATA8 - [C] 
Subtract 8-bit immediate signed binary data from AL register contents using 
twos complement arithmetic. If the Carry status was originally 1 decrement 
the result 




SBB 


AX,DATA16i 


ID YYYY 


4* 


X 








X 


X 


X! 


X 


X 


[AX] — [AX] -DATA16- [C] 
Subtract 16-bit immediate signed binary data from AX register contents 
using twos complement arithmetic. If the Carry status was originally 1 decre- 






















L- 




1 




ment the result 
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D 


1 


T 


S 


z 


A 


p 


c 




SBB 


RB.DATAB 


80 llOllddd YY 


4* 


X 








X 


X 


X 


X 


X 


[RB] — [RB] - DATA8 - [C] 




SBB 


RW,DATA16 


1 00000a 1 


4* 


X 








X 


X 


X 


X 


X 


Subtract 8-bit immediate signed binary data from RB register contents using 
twos complement arithmetic. If the Carry status was originally 1 decrement 
the result 
[RW] ^ [RW] - DATA 16 - [C] 




SBB 


DADDR, 


noilddd 
YY [YY] 

80aa011bbb 


17+EA 


X 








X 


X 


X 


X 


X 


Subtract 16-bit immediate signed binary data from RW register contents 
using twos complement arithmetic. If the Carry status was originally 1 decre- 
ment the result 
[EA] — [EA] - DATA8 - [C] 




SBB 


DATA8 
DADDR, 


[DISPKDISP] YY 
1 00000a 1 


17+EA 


X 








X 


X 


X 


X 


X 


Subtract 8-blt Immediate signed binary data from contents of data memory 
byte addressed by DADDR using twos complement arithmetic. If the Carry 
status was originally 1 decrement the result 
[EA] — [EA] - DATA 16 - [C] 


• 

3 


SUB 


DATA16 
AL,DATA8 


aaOllbbb 
[DISP][DISP]YY[YY] 

2CYY 


4* 


X 








X 


X 


X 


X 


X 


Subtract 1 6-blt Immediate signed binary data from contents of 1 6-bit data 
memory word addressed by DADDR using twos complement arithmetic. If the 
Carry status was originally 1 decrement the result 
[AL] - [AL] - DATA8 


e 
o 
O 

« 

5 


SUB 


AX,DATA16 


2D YYYY 


4* 


X 








X 


X 


X 


X 


X 


Subtract the 8-blt immediate signed binary data from AL register contents 
using twos complement arithmetic 
[AX] — [AX] - DATA 16 


O 

• 


SUB 


RB.DATAS 


80 inOlddd YY 


4* 


X 








X 


X 


X 


X 


X 


Subtract the 1 6-bit immediate signed binary data from AX register contents 
using twos complement arithmetic 
[RB] — [RB] - DATA8 


c 
E 
E 


SUB 


RW.DATAie 


81 inOlddd 


4* 


X 








X 


X 


X 


X 


X 


Subtract the 8-blt Immediate signed binary data from RB register contents 
using twos complement arithmetic 
[RW] — [RW] -DATA 16 




SUB 
SUB 


DADDR, 
DATA8 

DADDR, 


YYYY 

80aa101bbb 
(DISP][DISP1 YY 

1 00000a 1 


17+EA 
17+EA 


X 
X 








X 
X 


X 
X 


X 
X 


X 
X 


X 
X 


Subtract the 1 6-blt Immediate signed binary data from RW register contents 

using twos complement arithmetic 
[EA] — [EA] - DATA8 

Subtract the 8-bit immediate signed binary data from the contents of the data 

memory byte addressed by DADDR using twos complement arithmetic 
[EA] — [EA] -DATA 16 




TEST 


DATA1 6 
AL,DATA8 


aa101bbb 
[DISP][DISP]YY[YY1 

A8YY 


4* 




C 


) 




X 


X 


U 


X 





Subtract the 1 6-bit Immediate signed binary data from the contents of the 
16-bit data memory word addressed by DADDR using twos complement 
arithmetic 
[AL] AND DATA8 
AND the 8-bit Immediate data and AL register contents. Discard the result but 
adjust status s 
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and 8088 Instructions (Continued) 
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> 




















H 













D 


1 


T 


S 


z 


A 


p 









TEST 


AX,DATA16 


A9 YYYY 


4* 











X 


X 


U 


X 





I AX] AND DATA 16 
AND the 1 6-bit immediate data and AX register contents. Discard the result 
but adjust status flags 




TEST 


RB,DATA8 


F6 llOOOddd YY 


5* 











X 


X 


U 


X 





[RB] AND DATA8 
AND the 8-bit immediate data and RB register contents. Discard the result but 
adjust status flags 




TEST 


RW,DATA16 


F7 nOOOddd 
YYYY 


5* 











X 


X 


u 


X 





[RW] AND DATA 16 
AND the 1 6-bit immediate data and RW register contents. Discard the result 
but adjust status flags 


0) 


TEST 


DADDR, 


F6 aaOOObbb 


11+EA 











X 


X 


u 


X 





[EA] AND DATA8 


3 




DATA8 


[DISPllDISP] YY 






















AND the 8-bit immediate data and the contents of the data memory location 


E 




























addressed by DADDR. Discard the result but adjust status flags 


o 


TEST 


DADDR, 


F7 aaOOObbb 


1 1 +EA 











X 


X 


u 


X 





[EA] AND DATA16 


• 




DATA16 


[DISP][DISP]YYYY 






















AND the 1 6-bit immediate data and the contents of the 1 6-bit data memory 


5 




























word addressed by DADDR. Discard the result but adjust status flags 


s 


XOR 


AL,DATA8 


34 YY 


4* 











X 


X 


u 


X 





[AL] — [AL] XOR DATA8 


B 




























Exclusive OR 8-bit immediate data with AL register contents 


.2 


XOR 


AX,DATA16 


35 YYYY 


4* 











X 


X 


u 


X 





[AX] — [AX]X0RDATA16 






























Exclusive OR 1 6-bit immediate data with AX register contents 


E 


XOR 


RB.DATAB 


80 imOddd YY 


4* 











X 


X 


u 


X 





[RB] — [RB] XOR DATA8 






























Exclusive OR 8-bit immediate data with RB register contents 




XOR 


RW,DATA1 6 


81 IlllOddd 
YYYY 


4" 











X 


X 


u 


X 





[RW] — [RW] XOR DATA16 
Exclusive OR 1 6-bit Immediate data with RW register contents 




XOR 


DADDR, 
DATA8 


80aa010bbb 
[DISP][DISP] YY 


17+EA 











X 


X 


u 


X 





[EA] — [EA] XOR DATA8 
Exclusive OR 8-bit immediate data with contents of the data memory byte ad- 
dressed by DADDR 




XOR 


DADDR, 
DATA 16 


81 aaOIObbb 
[DISP][DISP] 


17+EA 











X 


X 


u 


X 





[EA] — [EA] XOR DATA1 6 
Exclusive OR 1 6-bit immediate data with contents of the 1 6-bit data memory 








YYYY 






















word addressed by DADDR 




LOOP 


DISP8 


E2 DISP 


5 or 1 7" 




















[CX] — [CX] -1 If [CX] ¥=0 then [PC] — [PC] + DISP8 


g 




























Decrement CX register and branch if CX contents are not 


w 

•s 


LOOPE 


DISP8 


El DISP 


6 or 18" 




















[CX] — [CX] -1 If [CX] ^0 and [Z] = 1 then [PC] + DISP8 


1 




























Decrement CX register and branch if CX contents is not and Z status is 1 


o 
u 


LOOPNE 


DISP8 


EC DISP 


5 or 1 9" 




















[CX] — [CX] -1 If [CX] ^0 and [Z] = then [PC] «- [PC] + DISP8 


e 
O 




























Decrement CX register and branch if CX contents is not and Z status is 


£ 


LOOPNZ 


DISP8 
























See LOOPNE 


s 


LOOPZ 


DISP8 
























See LOOPE 


m 


JA 


DISP8 


77 DISP 


4 or 16" 




















[PC] — [PC] + DISP8 
Branch if C or Z is 
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§i 
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^^ 


^^ 


1- 













D 


1 


T 


S 


z 


A 


P 


C 








JAE 


DISP8 


73 DISP 


4 or 1 6" 




















[PC] — [PC] + DISPS 
Branch if C Is 






JB 


DISP8 


72 DISP 


4 or 16" 




















[PC] — [PC] + DISPS 
Branch if C Is 1 






JBE 


DISP8 


76 DISP 


4 or 1 6" 




















[PC] — [PC] + DISPS 
Branch if C or Z is 1 






JCXZ 


DISP8 


E3 DISP 


6 or IS" 




















[PC] ^ [PC] + DISPS 
Branch if the CX register contents is 






JE 


DISP8 


74 DISP 


4 or 16" 




















[PC] ^ [PC] + DISPS 
Branch if Z is 1 






JG 


DISP8 


7F DISP 


4 or 16" 




















[PC] — [PC] + DISPS 
Branch if Z is or the S and statuses are the 


same 




JGE 


DISP8 


7D DISP 


4 or 16" 




















[PC] — [PC] + DISPS 
Branch if the S and statuses are the same 




^5 


JL 


DISP8 


7C DISP 


4 or 16" 




















[PC] — [PC] + DISPS 




c 




























Branch if the S and statuses differ 




e 


JLE 


DISP8 


7E DISP 


4 or 16" 




















[PC] ^ [PC] + DISPS 




o 
O 




























Branch if Z is 1 or the S and statuses differ 




c 


JNA 


DISP8 
























See JBE 




_o 


JNAE 


DISP8 
























See JB 




1 


JNB 


DISP8 
























See JAE 




o 
o 


JNBE 


DISP8 
























See JA 




c 

o 


JNE 


DISP8 


75 DISP 


4 or 1 6" 




















[PC] ^ [PC] + DISPS 




X 




























Branch if Z is 




e 


JNG 


DISP8 
























See JLE 




CO 


JNGE 
JNL 
jnle 
JNO 

JNP 

JNS 

JNZ 
JO 

JP 

JPE 


DISP8 
DISP8 
dispS 
DISP8 

DISPS 

DISPS 

DISPS 
DISPS 

DISPS 

DISPS 


71 DISP 
7B DISP 
79 DISP 

70 DISP 
7A DISP 


4 or 1 6" 
4 or 16" 
4 or 16" 

4 or 16" 
4 or 1 6" 




















See JL 

See JGE 

See JG 
[PC] ^ [PC] + DISPS 

Branch if is 
[PC] — [PC] + DISPS 

Branch if P is 
[PC] — [PC] + DISPS 

Branch if S is 

See JNE 
[PC] — [PC] + DISPS 

Branch if is 1 
[PC] — [PC] + DISPS 

Branch if P is 1 

See JP 
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Object Code 


Clock Cycles 


Statuses 


Operation Performed 





D 


1 


T 


S 


z 


A 


p 


C 


c 
o 
o 

8 

m 


JPO 
JS 

JZ 


DISP8 
DISP8 

DISP8 


78DISP 


4 or 1 6" 




















See JNP 
[PC] ^ iPC] + DISP8 
Branch if S is 1 
See JE 


§ 

1 
f 

1 

« 

.2 
'5» 
« 


MOV 
MOV 
MOV 
MOV 
XCHG 
XCHG 
XCHG 


RBD,RBS 
RWD.RWS 
SR,RW 
RW,SR 
AX,RW 
RB.RB 
RW,RW 


BAIIdddsss 
8B lldddsss 
8E 1 1 0rrsss 
8C llOrrddd 
lOOIOreg 

86 1 1 regreg 

87 1 1 regreg 


2* 
2" 
2* 
2* 
3* 
4' 
4" 




















[RBD] — [RBS] 

Move the contents of any RB register to any RB register 
[RWD] — [RWS] 

Move the contents of any RW register to any RW register 
[SR] - [RWSl 

Move the contents of any RW register to any Segment register 
[RWD] — [SR] 

Move the contents of any Segment register to any RW register 
[AX] — — [RW] 

Exchange the contents of AX and any RW register 
[RB] - — [RB] 

Exchange the contents of any two RB registers 
[RW] ^ ^ [RW] 

Exchange the contents of any iwo RW registers 


1 

« 

B 

1 

e 


CMPS 
CMPS 
LODS 
LODS 
MOVS 

MOVS 


BD.BS 
WD.WS 

BD.BS 
WD.WS 

BD.BS 

WD.WS 


A6 
A7 
AC 
AD 
A4 

A5 


22 
22 
12 
12 
18 

18 


X 
X 


l/D 
l/D 
l/D 
l/D 
l/D 

l/D 






X 
X 


X 
X 


X 
X 


X 
X 


X 
X 


[[SI]] - [[Dl]], [SI] - [SI] + 1. [Dl] - [Dl] ± 1 

Compare the data bytes addressed by the SI and Dl Index registers using 

string data addressing* 
[[SI]] - [[Dl]]. [SI] - [SI] + 2. [Dl] ^ [Dl] ± 2 

Compare the 1 6-bit data words addressed by the SI and Dl Index registers 

using string data addressing* 
[AL] - [[SI]]. [SI] - [SI] ± 1 

Move a data byte from the location addressed by the SI Index register to the 

AL register using string data addressing 
[AX] *- [[SI]]. [SI] ^ [SI] ± 1 

Move a data word from the 1 6-bit location addressed by the SI Index register 

to the AX register using string data addressing 
[[Dl]] — [[SI]], [SI] — [SI] ± 1, [Dl] — [Dl] + 1 

Move a data byte from the location addressed by the SI Index register to the 

extra segment location addressed by the Dl register using string data address- 
ing* 
[[Dl]] - [[SI]]. [SI] ^ [SI] ± 2, [Dl] - [Dl] ± 2 

Move a 1 6-bit data word from the location addressed by the SI Index register 

to the extra segment location addressed by the Dl Index register using string 

data addressing* 

* For these instructions, the default destination segment register cannot be 
overriden. 



Table 5-4. A Summary of 8086 and 8088 Instructions (Continued) 



(- 


Mnemonic 


Operand (s) 


Object Code 


Clock Cycles 


Statuses 


Operation Performed 


O 


D 


' 


T 


S 


z 


A 


p 


c 


1 

o 

e 
(0 

« 

« 

e 
S 

1- 


REP 

SCAS 
SCAS 
STOS 
STOS 


N 

BD.BS 
WD.WS 

BD.BS 
WD.WS 


niiooiz 

AE 
AF 
AA 
AB 


+2 per loop 

15 
15 
11 
11 


X 
X 
X 
X 


l/D 

l/D 
l/D 
l/D 
l/D 






X 
X 
X 
X 


X 
X 
X 
X 


X 
X 
X 
X 


X 
X 
X 
X 


X 
X 
X 
X 


Repeat the next sequential Instruction (which must be a Block Transfer and 
Search Instruction) until CX contents decrements to 0. Decrement CX con- 
tents on each repeat. If the next instruction is CMPB, CMPW, SCAB, or 
SCAW then repeat until CX contents decrements to or Z status does not 
equal N 

lAL] - [[Dl]]. [Dll - [Dl] ± 1 
Compare AL register contents with the extra segment data byte addressed by 
the Dl Index register using string data addressing 

[AX] - [[Dl]]. [Dll - [Dl] ± 2 
Compare AX register contents with the extra segment 1 6-bit data ord ad- 
dressed by the Dl Index register using string data addressing 

[[Dl]] - [AL], [Dl] - [Dl] ± 1 
Store the AL register contents in the extra segment data memory byte ad- 
dressed by the Dl Index register using string data addressing 

[[Dl]] - [AX]. [Dl] - [Dl] ± 2 
Store the AX register contents in the extra segment 1 6-bit data memory word 
addressed by the Dl Index register using string data addressing 


2 
& 

O 

S 

M 

i 


ADC 
ADC 

ADD 
ADD 
AND 
AND 
CBW 
CMP 

CMP 

CWD 


RBD.RBS 
RWD.RWS 

RBD.RBS 
RWD.RWS 

RBD.RBS 
RWD.RWS 

RBD.RBS 
RWD.RWS 


12 lldddsss 

13 lldddsss 

02 lldddsss 

03 lldddsss 

22 lldddsss 

23 lldddsss 

98 
3A lldddsss 

3B lldddsss 

99 


3* 
3* 

3* 
3* 
3* 
3" 
2* 
3* 

3* 

5 


X 
X 

X 
X 




X 
X 








X 
X 

X 
X 
X 
X 

X 
X 


X 
X 

X 
X 
X 
X 

X 
X 


X 
X 

X 
X 

u 
u 

X 
X 


X 
X 

X 
X 
X 
X 

X 
X 


X 
X 

X 
X 



X 
X 


[RBD] — [RBD] + [RBS] + [C] 

Add the 8-bit contents of register RBS. plus the Carry status, to register RBD 
[RWD] ^ [RWD] + [RWS] + [C] 

Add the 1 6-bit contents of register RWS. plus the Carry status, to register 

RWD 
[RBD] — [RBD] + [RBS] 

Add the 8-bit contents of register RBS to register RBD 
[RWD] — [RWD] + [RWS] 

Add the 1 6-bit contents of register RWS to register RWD 
[RBD] <- [RBD] AND [RBS] 

AND the 8-bit contents of register RBS with register RBD 
[RWDl — [RWD] AND [RWS] 

AND the 1 6-bit contents of register RWS with register RWD 
[AH] — [AL7] 

Extend AL sign bit into AH 
[RBD] - fRBS] 

Subtract the contents of register RBD from register RBS. Discard the result. 

but adjust status flags 
[RWD]- [RWS] 

Subtract the contents of register RWD from register RWS. Discard the result. 

but adjust status flags 
[DX] — [AX15] 

Extend AX sign bit into DX 



Ol — 











Table 5-4. A Su 


Timarv 


of 8086 and 8088 Instructions (Continued) 


I 


Mnemoniq 


Operand(s) 


Object Code 


Clock Cycles 


Statuses 


Operation Performed 


> 




















H 













D 


1 


T 


S 


z 


A 


p 


c 






DIV 


RBS 


F6 nnosss 


80-90 


U 








u 


u 


u 


u 


u 


[AX] ^ [AX]/(RBS] 
Divide the 1 6-bit contents of AX by the 8-bit contents of RBS. Store the in- 
teger quotient in AL and the remainder in AH. If the quotient is greater than 
FFig, execute a "divide by 0" interrupt 




DIV 


RWS 


F7 nnosss 


144-162 


U 








u 


u 


u 


u 


u 


[DXl [AX] — [DX] [AX]/[RWS1 
Divide the 32-bit contents of registers DX (high-order) and AX (low-order) by 
the 1 6-bit contents of RWS. Store the integer quotient in AX and the re- 
mainder in DX. If the quotient is greater than FFFFi g, execute a "divide by 0" 
interrupt 




IDIV 


RBS 


F6 111 11 sss 


101-112 


u 








u 


u 


u 


u 


u! 


[AX] *- [AX]/[RBS] 
Divide the 1 6-bit contents of register AX by the 8-bit contents of RBS, treat- 
ing both contents as signed binary numbers. Store the quotient, as a signed 
binary number, in AL. Store the remainder, as an unsigned binary number, in 


1 




























AX. Store the remainder, as an unsigned binary number, in AH. If the quotient 


3 
c 




























is greater than 7Fig, or less than -BO-jg, execute a "divide by 0" interrupt 


1 


IDIV 


RWS 


F7 linisss 


165-184 


u 








u 


u 


u 


u 


u 


[DX] [AX] - [DX] [AX]/[RWS] 


8 




























Divide the 32-bit contents of register^X (high-order) and AX (low-order) by 


s 




























the 1 6-bit contents of RWS. Treat both contents as signed binary numbers. 






























Store the quotient, as a signed binary number, in AX. Store the remainder, as 


o 




























an unsigned binary number. In AH. If the quotient is greater than 7FFFi g, or 


4) 




























less than -BOOOig, execute a "divide by 0" interrupt 


« 


IMUL 


RBS 


F6 mOlsss 


80-98 


X 








u 


u 


u 


u 


X 


[AX] - [AL] . [RBS] 


2 




























Multiply the 8-bit contents of register AL by the contents of RBS. Treat both 


1 




























numbers as signed binary numbers. Store the 1 6-bit product in AX 


• 


IMUL 


RWS 


F7 11101SSS 


128-154 


X 








u 


u 


u 


u 


X 


[DX] [AX] — [AX] • [RWS] 


M 




























Multiply the 1 6-bit contents of register AX by the 1 6-bit contents of RWS. 






























Treat both numbers as signed binary numbers. Store the 32-bit product in DX 




























(high-order word) and AX (low-order word) 




MUL 


RBS 


F6 IIIOOsss 


70-77 


X 








u 


u 


u 


u 


X 


[AX] ^ [AL] . [RBS] 
Multiply the 8-bit contents of register AL by the contents of RBS. Treat both 
numbers as unsigned binary numbers. Store the 1 6-bit product in AX 




MUL 


RWS 


F7 IIIOOsss 


118-133 


X 








u 


u 


u 


u 


X 


[DX] [AX] — [AX] . [RWS] 
Multiply the 1 6-bit contents of register AX by the 1 6-bit contents of RWS. 
Treat both numbers as unsigned binary numbers. Store the 32-bit product in 
DX (high-order word) and AX (low-order word) 




OR 


RBD.RBS 


DA lldddsss 


3* 











X 


X 


u 


X 





[RBD] *- [RBD] OR [RBS] 

: OR the 8-bit contents of register RBS with register RBD 




OR 


RWD.RWS 


OB lldddsss 


3* 











X 


X 


u 


X 


01 


[RWD] ^ [RWD] OR [RWS] 
OR the 1 6-bit contents of register RWS with register RWD 



Table 5-4. A Summary of 8086 and 8088 Instructions (Continued) 



> 
1- 


Mnemonic 


Operand(s) 


Object Code 


Clock Cycles 


Statuses 


Operation Performed 





D 


1 


T 


s 


z 


A 


p 


c 


1 

3 
C 

e 
o 
O 

« 

2 

o 

• 
tn 
'5> 

• 
E 

« 
w 
'5> 

& 


SBB 

SBB 

SUB 

SUB 

TEST 

TEST 

XOR 
XOR 


RBD.RBS 
RWD.RWS 

RBD.RBS 
RWD.RWS 

RBD.RBS 

RWD.RWS 

RBD.RBS 
RWD.RWS 


1A lldddsss 
IB lldddsss 
2A lldddsss 
2B 1 1 dddsss 

84 1 1 regreg 

85 1 1 regreg 

30 lldddsss 

31 lldddsss 


3' 

3- 

3* 

3* 

3" 

3* 

3* 
3" 


X 
X 
X 
X 















X 

X 

X 

X 

X 

X 

X 
X 


X 

X 

X 

X 

X 

X 

X 
X 


X 
X 
X 
X 

u 

u 

u 
u 


X 

X 

X 

X 

X 

X 

X 
X 


X 

X 

X 

X 









[RBD] ^ [RBD] - [RBS] - [C] 
Subtract the 8-bit contents of register RBS from RBD using twos complement 
arithmetic. If the Carry status was originally 1 decrement the result 

[RWD] — [RWD] - [RWS] - [CI 
Subtract the 1 6-bit contents of register RWS from RWD using twos comple- 
ment arithmetic. If the Carry status was originally 1 decrement the result 

[RBD] ^ [RBD] - [RBS] 
Subtract the 8-bit contents of register RBS from RBD using twos complement 
arithmetic 

[RWD] — [RWD] - [RWS] 
Subtract the 1 6-bit contents of register RWS from RWD using twos comple- 
ment arithmetic 

[RBD] AND [RBS] 
AND the 8-bit contents of register d and register RBS. Discard the result, but 
adjust status flags 

[RWD] AND [RWS] 
AND the 16-bit contents of register RWD and register RWS. Discard the 
result, but adjust status flags 

[RBD] — [RBD] XOR [RBS] 
Exclusive OR the 8-bit contents of register RBS with register RBD 

[RWD] — [RWD] XOR [RWS] 
Exclusive OR the 1 6-bit contents of register RWS with register RWD 


2 
o 

M 

'5> 

« 


AAA 
AAD 

AAM 
AAS 

DAA 
DAS 
DEC 
DEC 


RB 
RW 


37 
D5 0A 

D4 0A 
3F 

27 

2F 

FE llOOIddd 

OlOOIddd 


4* 
60 

83 
4' 

4* 
4* 
3" 
2* 


u 
u 

u 
u 

u 
u 

X 
X 








u 

X 
X 

u 

X 
X 
X 
X 


u 

X 
X 

u 

X 
X 
X 
X 


X 

u 
u 

X 

X 
X 
X 
X 


u 

X 
X 

u 

X 
X 
X 
X 


X 

u 
u 

X 

X 
X 


ASCII adjust Al register contents for addition (as described in accompanying 

text) 

Decimal adjust dividend in AL prior to dividing an unpacked decimal divisor, 

to generate an unpacked decimal quotient. (See accompanying text for 

details) 

After multiplying o unpacked decimal operands, adjust product in AX to 

become an unpacked decimal result. (See accompanying text for details) 

After subtracting two unpacked decimal numbers, adjust the difference in AL 

so that it too is an unpacked decimal number. (See accompanying text for 

details) 

After adding two packed decimal numbers, adjust the sum in AL so that it too 

is a packed decimal number. (See accompanying text for details) 

After subtracting two packed decimal numbers, adjust the difference In AL so 

that it too is a packed decimal number. (See accompanying text for details) 

[RB]^[RB] -1 
Decrement the 8-bit contents of register RB 

[RW] — [RW] -1 
Decrement the 1 6-bit contents of register RW 











Table 5-4. A Summary 


of 8086 and 8088 Instructions (Continued) 


• 










Statuses 




§: 


Mnemonic 


Operand(s) 


Object Code 


Clock Cycles 




Operation Performed 




















t- 













D 


1 


T 


S 


z 


A 


P 


C 






INC 


RB 


FE 1 1 OOOddd 


3' 


X, 








X 


"x 


"x" 


x" 




[RB] — [RB]+1 
Increment the 8-blt contents of register RB 




INC 


RW 


OlOOOddd 


2" 


X 








X 


X 


X 


X 




[RW] — [RW] +1 
Increment the 1 6-bit contents of register RW 




NEG 


RB 


F6 llOllddd 


3* 


X 








X 


X 


X 


X 


X 


[RB] — [RB] +1 
Twos complement the 8-bit contents of register RB 




NEG 


RW 


F7 noilddd 


3' 


X 








X 


X 


X 


X 


X 


[RW] — [RW] + 1 
Twos complement the 1 6-bit contents of register RW 




NOT 


RB 


F6 llOIOddd 


3* 




















[RB] - [RB] 


1 




























Ones complement the 8-bit contents of register RB 


c 


NOT 


RW 


F7 noiOddd 


3* 




















[RW] — [RW] 


c 
o 




























Ones complement the 16-bit contents of register RW 


o 


RCL 


RB,N 


IIOIOOvO nOIOddd 




X 
















X 


Rotate left through Carry the 8-bit contents of RB register, or the 1 6-bit 


B 


RCL 


RW,N 


nOIOOvl nOIOddd 




X 
















X 


contents of RW register, as illustrated for memory operate 


S 
o 


RCR 


RBN 


IIOIOOvO noilddd 




X 
















X 


Rotate right through Carry the 8-bit contents of RB register, or the 16-bit 


a. 
O 


RCR 


RW,N 


IIOIOOvl noilddd 




X 
















X 


contents of RW register, as illustrated for memory operate 


o 


ROL 


RB,N 


nOIOOvO 11 OOOddd 


N=1 2* 
N>1 4N+8 


X 
















X 


Rotate left the 8-bit contents of RB register, or the 1 6-bit contents of RW 


.2 


ROL 


RW,N 


IIOIOOvl 11 OOOddd 


X 
















X 


register as illustrated for memory operate 


• 


ROR 
ROR 


RB,N 
RW,N 


IIOIOOvO llOOIddd 
IIOIOOvl nOOIddd 




X 
X 
















X 
X 


Rotate right the 8-bit contents of RB register, or the 1 6-bit contents of RW 
register, as illustrated for memory operate 




SAL 


RB,N 


IIOIOOvO niOOddd 




X 








X 


X 


u 


X 


X 


Shift left the 8-bit contents of RB register, or the 1 6-bit contents of RW 




SAL 


RW.N 


IIOIOOvl IllOOddd 




X 








X 


X 


u 


X 


X 


register, as illustrated for memory operate 




SAR 


RB,N 


IIOIOOvO Tiniddd 




X 








X 


X 


u 


X 


X 


Shift right the 8-bit contents of register RB, or the 1 6-bit contents of register 




BAR 


RW.N 


IIOIOOvl nniddd 




X 








X 


X 


u 


X 


X 


RW, as illustrated for memory operate 




SHL 


RB,N 






X 








X 


X 


u 


X 


X 


See SAL 




SHL 


RW,N 






X 








X 


X 


u 


X 


X 


See SAL 




SHR 


RB.N 


IIOIOOvO inOlddd 


N=1 2* 


X 








X 


X 


u 


X 


X 


Shift right the 8-bit contents of register RB, or the 1 6-bit contents of register 




SHR 


RW,N 


IIOIOOvl niOlddd 


N>1 4N+8 










X 


X 


u 


X 


X 


RW, as illustrated for memory operate 




POP 


DADDR 


BF aaOOObbb 
[DISPKDISP] 


17+EA 




















[EA] - [[SP]], [SP] - [SP] + 2 
Load the 1 6-bit Stack word, addressed using Stack addressing, into the 1 6- 
bit data memory word addressed by DADDR. Increment SP by 2 




POP 


RW 


OlOllddd 


8 




















[RW or SR] — [[SP]], [SP] — [SP] + 2 




POP 


SR 


OOOrr1 1 1 


8 




















Load the 16-bit Stack word, addressed using Stack addressing, into the 


IS 




























specified 1 6-bit register. Increment SP by 2. 


8 

(0 


POPF 
PUSH 


DADDR 


9D 

FFaallObbb 
[DISP][DISP] 


8 
16+EA 


X 


X 


X 


X 


X 


X 


X 


X 


X 


[SFR] — [[SP]], [SP] — [SP] + 2 

Load the 16-bit Stack word, addressed using Stack addressing, into the 

Status Flags register 
[SP] - [SP] -2, [[SP]] - [EA] 

Store the 1 6-bit contents of the data memory word addressed by DADDR in 

the 1 6-bit Stack word addressed using Stack addressing. Decrement SP by 2 
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%. 


Mnemonic 


Operand(s) 


Object Code 


Clock Cycles 


Statuses 


Operation Performed 


> 




















t- 













D 


1 


T 


s 


z 


A 


P 









PUSH 


RW 


OlOIOrrr 


11 




















[SP] — ISP] -2. [(SPU — [RW or SR] 


i 


PUSH 


SR 


OOOrrllO 


10 




















Store the contents of the specified 1 6-bit register in the 1 6-bit Stack word 


o 
o 




























addressed using Stack addressing. Decrennent SP by 2 


^ 


PUSHF 


90 


10 






















ISPl ^ [SP] +2, [[SPj] *- [SFR] 


o 
n 




























Store the Status flags register contents in the 1 6-bit Stack word addressed 


W 




























using Stack addressing. Decrement SP by 2 


tn 


INT 


3 


CC 


52 






















Execute a software interrupt and vector through table entry 3 


a 


INT 


V 


CD YY 


51 






















Execute a software interrupt and vector through table entry V 


t 


INTO 




CE 


4 or 53 






















If the status is 1 , execute a software interrupt and vector through table en- 


c 


IRET 




CF 


24 




















try 10i6 

Return from interrupt service routine 




CLC 




F8 


2' 





















[C]-0 
Clear Carry status 




CLD 




FC 


2' 





















[D]-0 
Clear Decrement/Increment select 




CLI 




FA 


2' 





















[1] - 
Clear Interrupt enable status, disabling all interrupts 




CMC 




F5 


2* 


















X 


[C] - [C] 
Complement Carry status 




LAHF 




9F 


4' 




















Transfer flags to AH register as follows: 


5 




























7 6 5 4 3 2 1 Bit no. 


1 1 














1 AH register 1 


S Z A P 1 C 


S 


SAHF 




9E 


4* 










X 


X 


X 


X 


X 


Transfer AH register contents to status flags as follows: 
7 6 5 4 3 2 1 Bit no. 


1 














1 AH register 1 


S Z A P C 




STC 




F9 


2* 


















1 


[C]-1 
Set Carry status to 1 




STD 




FD 


2* 




1 
















[D] - 1 
Set Decrement/Increment status to 1 




STI 




FB 


2* 






1 














[1] - 1 
Set interrupt enable status to 1, enabling all interrupts 



Table 5-4. A Summary of 8086 and 8088 Instructions (Continued) 



Mnemonic! 



Operand(s) 



Object Code 



Clock Cycles 



Statuses 



ODI TSZAPC 



Operation Performed 



ESC 



HLT 
LOCK 



SEG 



WAIT 
NOP 



DAODR 



SR 



IIOIIxxx 

aaxxxbbb 

[DISPIIDISP] 

F4 

FO 

001 regno 



9B 
90 



8+EA 



2* 
2* 



+ 2 



3+5n 
3* 



? - [EA] 
The contents of the data memory location addressed by DADDR Is read out of 
memory and placed on the data bus; however, it is not input to the CPU 
CPU Halt 

Guarantee the CPU bus control during execution of the next sequential in- 
struction 

The next sequential allowed memory reference instruction accesses the seg- 
ment identified by Segment register SR. See Table 20-1 for allowed memory 
reference instructions 

CPU enters the WAIT state until TEST pin receives a high input signal 
No operation (This is the same object code as XCHG, AX, AX.) 



Table 5-5. 8086 and 8088 Instruction Mnemonics 



Instruction 


Object Code 


Bytes 


Clock 
Periods 


AAA 




37 


1 


4* 


AAD 




D5 OA 


2 


60 


AAM 




D4 0A 


2 


83 


AAS 




3F 


1 


4' 


ADC 


AL,DATA8 


14 YY 


2 


4* 


ADC 


AX,DATA16 


1 5 YYYY 


3 


4* 


ADC 


DADDR,DATA8 


BOaaOtObbb 
[DISP] [DISP] YY 


3. 4 or 5 


17+EA 


ADC 


DADDR,DATA16 


1 00000a 1 aaOIObbb 
[DISP] [DISP] YY[YY] 


3. 4. 5 or 6 


17+EA 


ADC 


DADDR.RB 


1 aasssbbb 
[DISP] [DISP] 


2, 3. or 4 


16+EA 


ADC 


DADDR.RW 


1 1 aasssbbb 
[DISP] [DISP] 


2. 3 or 4 


16+EA 


ADC 


RB.DADDR 


1 2 aadddbbb 
[DISP] [DISP] 


2. 3 or 4 


9+EA 


ADC 


RB,DATA8 


80 llOIOddd YY 


3 


4* 


ADC 


RBD.RBS 


12 lldddsss 


2 


3* 


ADC 


RW.DADDR 


1 3 aadddbbb 
[DISP] [DISP] 


2. 3 or 4 


9+EA 


ADC 


RW,DATA16 


1 00000a 1 llOIOddd 
YY[YY] 


3 or 4 


4* 


ADC 


RWD,RWS 


13 lldddsss 


2 


3* 


ADD 


AL.DATAB 


04 YY 


2 


4* 


ADD 


AX,DATA16 


05 YYYY 


3 


4- 


ADD 


DADDR,DATA8 


80 aaOOObbb 
[DISP] [DISP] YY 


3, 4 or 5 


17+EA 


ADD 


DADDR,DATA16 


100000a 1 aaOOObbb 
[DISP] [DISP] YY[YY] 


3. 4. 5 or 6 


17+EA 


ADD 


DADDR.RB 


GO aasssbbb 
[DISP] [DISP] 


2. 3 or 4 


16+EA 


ADD 


DADDR.RW 


01 aasssbbb 
[DISP] [DISP] 


2, 3 or 4 


16+EA 


ADD 


RB.DADDR 


02 aadddbbb 
[DISP] [DISP] 


2. 3 or 4 


9+EA 


ADD 


RB,DATA8 


80 llOOOddd YY 


3 


4- 


ADD 


RBD.RBS 


02 lldddsss 


2 


3* 


ADD 


RW.DADDR 


03 aadddbbb 
[DISP] [DISP] 


2. 3 or 4 


9+EA 


ADD 


RW.DATA16 


lOOOOOal nOOOddd 
YY[YY] 


3 or 4 


4' 


ADD 


RWD,RWS 


03 lldddsss 


2 


3- 


AND 


AL.DATAB 


24 YY 


2 


4* 


AND 


AX.DATA16 


25 YYYY 


3 


4- 


AND 


DADDR.DATA8 


80 aalOObbb 
[DISP] [DISP] YY 


3. 4 or 5 


17+EA 


AND 


DADDR.DATAIB 


81 aalOObbb 
[DISP] [DISP] YYYY] 


4, 5 or 6 


17 + EA 


AND 


DADDR.RB 


20 aasssbbb 
[DISP] [DISP] 


2. 3 or 4 


16+EA 


AND 


DADDR.RW 


21 aasssbbb 
[DISP] [DISP] 


2. 3 or 4 


16+EA 


AND 


RB.DADDR 


22 aadddbbb 
[DISP] [DISP] 


2. 3 or 4 


9+EA 


AND 


RB.DATAB 


80 1 1 1 0OOdddYY 


3 


4* 


AND 


RBD.RBS 


22 lldddsss 


23* 
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Table 5-5. 8086 and 8088 Inst 


uction Mnemonics (Cont 


nued) 




Instruction 


Object Code 


Bytes 


Clock 
Periods 


AND 


RW.DADDR 


23 aadddbbb 
[DISP] [DISP] 


2, 3 or 4 


9+EA 


AND 


RW.DATAie 


81 inoOsssYYYY 


4 


4* 


AND 


RWD,RWS 


23 lldddsss 


2 


3* 


CALL 


BRANCH 


E8 DISP DISP 


3 


19" 


CALL 


BRANCH.SEGM 


9A PPQQPPQQ 


5 


28" 


CALL 


DADDR 


FFaaOIObbb 
[DISP] [DISP] 


2. 3 or 4 


21+EA 


CALL 


DADDR,CS 


FFaaOllbbb 
[DISP] [DISP] 


2. 3 or 4 


37+EA" 


CALL 


RW 


FF llOIOreg 


2 


16" 


CBW 




98 




2 


CLC 




F8 




2* 


CLD 




FC 




2* 


CLI 




FA 




2* 


CMC 




F5 




2' 


CMP 


AL.DATAB 


3C YY 


2 


4* 


CMP 


AX,pATA16 


3D YYYY 


3 


4* 


CMP 


DADDR.DATAS 


SOaalllbbb 
[DISP] [DISP] YY 


3. 4 or 5 


10+EA 


CMP 


DADDR.DATAie 


1 00000a 1 aallbbb 
[DISP] [DISP] YY[YY] 


3. 4. 5 or 6 


10+EA 


CMP 


DADDR.RB 


38 aasssbbb 
[DISP] [DISP] 


2. 3 or 4 


9+EA 


CMP 


DADDR.RW 


39 aasssbbb 
[DISP] [DISP] 


2, 3 or 4 


9+EA 


CMP 


RB,DADDR 


3A aadddbbb 
[DISP] [DISP] 


2. 3 or 4 


9+EA 


CMP 


RB.DATAB 


80 nillddd YY 


3 


4* 


CMP 


RBD.RBS 


3A lldddsss 


2 


3* 


CMP 


RW.DADDR 


3B aadddbbb 
[DISP] [DISP] 


2. 3 or 4 


9+EA 


CMP 


RW.DATAie 


lOOOOOal nillddd 
YY[YY] 


3 or 4 


4* 


CMP 


RWD.RWS 


38 lldddsss 


2 


3* 


CMPS 


BD.BS 


A6 




22 


CMPS 


WD.WS 


A7 




22 


CWD 




99 




5 


DAA 




27 




4* 


DAS 




2F 




4* 


DEC 


DADDR 


1111 IllaaaaOOIbbb 
[DISP] [DISP] 


2, 3 or 4 


15+EA 


DEC 


RB 


FE llOOIddd 


2 


3* 


DEC 


RW 


OlOOIddd 


1 


2' 


DIV (8-bit) 


AX.DADDR 


F6aa110bbb 
[DISP] [DISP] 


2, 3 or 4 


(86-96)+EA 


DIV (16-bit) 


DX.DADDR 


F7aa110bbb 
[DISP] [DISP] 


2, 3 or 4 


(150-168)+EA 


DIV 


RBS 


F6 linOsss 


2 


80-90 


DIV 


RWS 


F7 nilOsss 


2 


144-162 


ESC 


DADDR 


1 101 Ixxx aaxxxbbb 
[DISP] [DISP] 


2, 3 or 4 


8+EA 


ESC 


RW 


1 101 Ixxx 1 1xxxreg 


2 


2 


HLT 




F4 


1 


2' 
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Table 5-5. 8086 and 8088 Instruction Mnemonics (Continued) 



Instruction 


Object Code 


Bytes 


Clock 
Periods 


IDIV 


AX.DADDR 


F6 aa111bbb 
[DISP] [DISP] 


2, 3 or 4 


(107-1 18)+EA 


IDIV 


DX,DADDR 


F7 aalllbbb 
[DISP] [DISP] 


2, 3 or 4 


{171-190)+EA 


IDIV 


RBS 


F6 linisss 


2 


101-112 


IDIV 


RWS 


F7 linisss 


2 


165-1B4 


IMUL 


AL.DADDR 


F6aa101bbb 
[DISP] [DISP] 


2, 3 or 4 


{86-104)+EA 


IMUL 


AX.DADDR 


F7 aalOlbbb 
[DISP] [DISP] 


2, 3 or 4 


(134-160)+EA 


IMUL 


RBS 


F6 inOlsss 


2 


B0-9B 


IMUL 


RWS 


F7 inOlsss 


2 


128-154 


IN 


AL[DX] 


EC 


1 


8 


IN 


AL,PORT 


E4 YY 


2 


10 


IN 


AX,[DX] 


ED 


1 


8 


IN 


AX.PORT 


E5 YY 


2 


10 


INC 


DADDR 


1111111a aaOOObbb 
[DISP] [DISP] 


2, 3 or 4 


15+EA 


INC 


RB 


FE llOOOddd 


2 


3* 


INC 


RW 


OlOOOddd 


1 


2' 


INT 


3 


CC 


1 


52 


INT 


V 


CD YY 


2 


51 


INTO 




CE 


1 


4 or 53 


IRET 




CF 


1 


24 


JA/JNBE 


DISP8 


77 DISP 


2 


4 or 1 6" 


JAE/JNB 


DISPB 


73 DISP 


2 


4 or 1 6" 


JB/JNAE 


DISP8 


72 DISP 


2 


4 or 1 6" 


JBE/JNA 


DISPB 


76 DISP 


2 


4 or 1 6" 


JCXZ 


DISPB 


63 DISP 


2 


6 or 1 8" 


JE/JZ 


DISPB 


74 DISP 


2 


4 or 1 6" 


JG/JNLE 


DISPB 


7F DISP 


2 


4 or 16" 


JGE/JNL 


DISPB 


7D DISP 


2 


4 or 16" 


JL/JNGE 


DISPB 


7C DISP 


2 


4 or 16" 


JLE/JNG 


DISPB 


7E DISP 


2 


4 or 16" 


JMP 


BRANCH 


111010a 1 DISP [DISP] 


2 or 3 


15" 


JMP 


BRANCH.SEGM 


EA PPQQ PPGQ 


5 


15" 


JMP 


DADDR 


FFaalOObbb 
[DISP] [DISP] 


2, 3 or 4 


18+EA 


JMP 


DADDR.CS 


FF aalOlbbb 
[DISP] [DISP] 


2 3 or 4 


24+EA 


JMP 


RW 


FF niOOreg 


2 


11 


JNE/JNZ 


DISPB 


75 DISP 


2 


4 or 16" 


JNO 


DISPB 


71 DISP 


2 


4 or 16" 


JNP/JPO 


DISPB 


68 DISP 


2 


4 or 16" 


JNS 


DISPB 


79 DISP 


2 


4 or 1 6" 


JO 


DISPB 


70 DISP 


2 


4 or 1 6" 


JP/JPE 


DISPB 


7A DISP 


2 


4 or 1 6" 


JS 


DISPB 


7B DISP 


2 


4 or 16" 


LAHF 




9F 


1 


4* 


LDS 


RW,DADDR 


C5 aadddbbb 
[DISP] [DISP] 


2, 3 or 4 


16+EA 


LEA 


RW.DADDR 


BD aadddbbb 
[DISP] [DISP] 


2, 3 or 4 


2+EA 


LES 


RW.DADDR 


C4 aadddbbb 
[DISP] [DISP] 


2, 3 or 4 


4 or 16" 


LOCK 




FO 


1 


2* 
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Table 5-5. 8086 and 8088 Instruction Mnemonics (Continued) 




Instruction 


Object Code 


Bytes 


Clock 
Periods 


LODS 


BS 


AC 


1 


12 


LODS 


WS 


AD 


1 


12 


LOOP 


DISP8 


E2 DISP 


2 


5 or 1 7" 


LOOPE/LOOPZ 


DISPB 


El DISP 


2 


6 or 1 8" 


LOOPNE/LOOPNZ 


DISP8 


EO DISP 


2 


5 or 1 9" 


MOV 


AL.LABEL 


AO PPQQ 


3 


10 


MOV 


AX,LABEL 


A1 PPQQ 


3 


10 


MOV 


DADDR,DATA8 


C6 aaOOObbb 
[DISP] [DISP] YY 


3, 4 or 5 


10+EA 


MOV 


DADDR.DATAie 


C7 aaOOObbb 
[DISP] [DISP] YYYY 


4, 5 or 6 


10+EA 


MOV 


DADDR.RB 


88 aasssbbb 
[DISP] [DISP] 


2, 3 or 4 


9+EA 


MOV 


DADDR.RW 


89 aasssbbb 
[DISP] [DISP] 


2, 3 or 4 


9+EA 


MOV 


DADDR.SR 


8C aaOrrbbb 
[DISP] [DISP] 


2, 3 or 4 


9+EA 


MOV 


LABEUAL 


A2 PPQQ 


3 


10 


MOV 


LABEL.AX 


A 3 PPQQ 


3 


10 


MOV 


RB.DADDR 


8A aadddbbb 
[DISP] [DISP] 


2, 3 or 4 


8+EA 


MOV 


RB,DATA8 


lOIIOddd YY 


2 


4* 


MOV 


RBD.RBS 


8A 11dddsss 


2 


2* 


MOV 


RW.DADDR 


8B aadddbbb 
[DISP] [DISP] 


2, 3 or 4 


8+EA 


MOV 


RW,DATA16 


101 llddd YYYY 


3 


4* 


MOV 


RW.SR 


8C 1 1 0rrsss 


2 


* 


MOV 


RWD.RWS 


8B lldddsss 


2 


• 


MOV 


SR.DADDR 


8E aaOrrbbb 
[DISP] [DISP] 


2, 3 or 4 


8+EA 


MOV 


SR.RW 


8E 1 1 0rrsss 


2 


* 


MOVS 


BD.BS 


A4 


1 


18 


MOVS 


WD.WS 


A5 


1 


18 


MUL (8-bit) 


AL.DADDR 


F6aa100bbb 
[DISP] [DISP] 


2, 3 or 4 


(76-83)+EA 


MUL (16-bit) 


AX.DADDR 


F7 aalOObbb 
[DISP] [DISP] 


2, 3 or 4 


(124-139)+EA 


MUL 


RBS 


F6 1 1 1 0Osss 


2 


70-77 


MUL 


RWS 


F7 11100 


2 


118-133 


NEG 


DADDR 


IlllOllaaaOllbbb 
[DISP] [DISP] 


2, 3 or 4 


16+EA 


NEG 


RB 


F5 llOllddd 


2 


3' 


NEG 


RW 


F7 noilddd 


2 


3* 


NOP 




90 


1 


3* 


NOT 


DADDR 


linOllaaaOIObbb 
[DISP] [DISP] 


2, 3 or 4 


16+EA 


NOT 


RB 


F6 IIOIOsss 


2 


3* 


NOT 


RW 


F7 IIOIOsss 


2 


3' 


OR 


AL,DATA8 


OC YY 


2 


4* 


OR 


AX.DATAI 6 


OD YYYY 


3 


4' 


OR 


DADDR.DATA8 


BOaaOOIbbb 
[DISP] [DISP] YY 


3, 4 or 5 


17+EA 


OR 


DADDR.DATAie 


81 aaOOIbbb 
[DISP] [DISP] YYYY 


4, 5 or 6 


17+EA 
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Table 5-5. 8086 and 8088 Instruction Mnemonics (Continued) 




Instruction 


Object Code 


Bytes 


Clock 
Periods 


OR 


DADDR.RB 


08 aasssbbb 
[DISP] [DISP] 


2. 3 or 4 


16+EA 


OR 


DADDR.RW 


09 aasssbbb 


2, 3 or 4 


16+EA 


OR 


RB.DADDR 


OA aadddbbb 
[DISP] [DISP] 


2. 3 or 4 


9+EA 


OR 


RB,DATA8 


80 llOOIddd YY 


3 


4* 


OR 


RBD.RBS 


OAlldddsss 


2 


3* 


OR 


RW.DADDR 


OB aadddbbb 
[DISP] [DISP] 


2. 3 or 4 


9+EA 


OR 


RW,DATA16 


81 IIOOIdddYYYY 


4 


4* 


OR 


RWD.RWS 


OB lldddsss 


2 


3* 


OUT 


AL,[DX] 


EE 


1 


8 


OUT 


AL.PORT 


E6 YY 


2 


10 


OUT 


AX,[DX] 


EF 


1 


8 


OUT 


AX.PORT 


E7YY 


2 


10 


POP 


DADDR 


8F aaOOObbb 
[DISP] [DISP] 


2, 3 or 4 


17+EA 


POP 


RW 


0101 Iddd 


1 


8 


POP 


SR 


OOOrr1 1 1 


1 


8 


POPF 




9D 


1 


8 


PUSH 


DADDR 


FFaallObbb 
[DISP] [DISP] 


2. 3 or 4 


16+EA 


PUSH 


RW 


OlOIOsss 


1 


11 


PUSH 


SR 


OOOrrllO 


1 


10 


PUSHF 




9C 


1 


10 


RCL 


DADDR.N 


llOIOOvaaaOIObbb 
[DISP] [DISP] 


2. 3 or 4 


N=1 15+EA 
N> 4N+20+EA 


RCL 


RB,N 


IIOIOOvO IIOIOsss 


2 


N=1 2* 
N>1 4N+8 


RCL 


RW,N 


IIOIOOvl IIOIOsss 


2 




RCR 


DADDR.N 


llOIOOvaaaOllbbb 
[DISP] [DISP] 


2, 3 or 4 


N=1 15+EA 
N> 4N+20+EA 


RCR 


RB,N 


IIOIOOvO IIOIIsss 


2 


N=1 2* 
N>1 4N+8 


REP 


N 


nnooiz 


1 


+ 2 


RET 




C3 


1 


8" 


RET 


CS 


CB 


1 


12" 


RET 


CS,DATA16 


CA YYYY 


3 


18" 


RET 


DATA 16 


C2 YYYY 


3 


17" 


ROL 


DADDR.N 


llOIOOvaaaOOObbb 
[DISP] [DISP] 


2. 3 or 4 


N=1 15+EA 
N>1 4N+20+EA 


ROL 


RB,N 


IIOIOOvO llOOOddd 


2 


N = 1 T 
N>4N + 8 


ROL 


RW,N 


IIOIOOvl nOOOddd 


2 




ROR 


DADDR.N 


1 lOIOOva aaOOIbbb 
[DISP] [DISP] 


2. 3 or 4 


N=1 15+EA 
N>1 4N+20+EA 


ROR 


RB.N 


IIOIOOvO nOOIddd 


2 


N=1 2* 
N>1 4N+8 


ROR 


RW.N 


IIOIOOvl llOOIddd 


2 




SAHF 




9E 


1 


4* 


SAL/SHL 


DADDR.N 


llOIOOvaaalOObbb 
[DISP] [DISP] 


2. 3 or 4 


N=1 15+EA 
N>1 4N+20+EA 


SAL/SHL 


RB.N 


IIOIOOvO inOOddd 


2 


N=1 2* 
N>1 4N+8 


SAL/SHL 


RW.N 


IIOIOOvl inOOddd 


2 
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Table 5-5. 8086 and 8088 Instruction Mnennonics (Continued) 






Instruction 


Object Code 


Bytes 


Clock 
Periods 


SAR 


DADDR.N 


llOIOOvaaalllbbb 
[DISP] [DISP] 


2. 3 or 4 


N=1 15+EA 
N>1 4N+20+EA 


SAR 


RB,N 


IIOIOOvO liniddd 


2 


N=1 2* 
N>1 4N+8 


SAR 


RW,N 


IIOIOOvl liniddd 


2 




SBB 


AL.DATAB 


1C YY 


2 


4* 


SBB 


AX,DATA16 


1 D YYYY 


3 


4* 


SBB 


DADDR,DATA8 


80 aaOllbbb 
[DISP] [DISP] YY 


3, 4 or 5 


17+EA 


SBB 


DADDR,DATA16 


1 00000a 1 aaOllbbb 
[DISP] [DISP] YY[YY] 


3. 4. 5 or 6 


17+EA 


SBB 


DADDR,RB 


1 8 aasssbbb 
[DISP] [DISP] 


2, 3 or 4 


16+EA 


SBB 


DADDR.RW 


1 9 aasssbbb 
[DISP] [DISP] 


2. 3 or 4 


16+EA 


SBB 


RB,DADDR 


lAaadddbbb 
[DISP] [DISP] 


2. 3 or 4 


9+EA 


SBB 


RB,DATA8 


80 llOllddd YY 


3 


4* 


SBB 


RBD.RBS 


1A 11dddsss 


2 


3* 


SBB 


RW.DADDR 


1 B aadddbbb 
[DISP] [DISP] 


2, 3 or 4 


9+EA 


SBB 


RW,DATA16 


lOOOOOal noilddd 
YY[YY] 


3 or 4 


4* 


SBB 


RWD.RWS 


IBIIdddsss 


2 


3' 


SCAS 


BD 


AE 


1 


15 


SCAS 


WD 


AF 


1 


15 


SEG Prefix 


SR 


OOlrrlOl 


1 


+2 


SHR 


DADDR.N 


nOIOOva aalOlbbb 
[DISP] [DISP] 


2, 3 or 4 


N=1 15+EA 
N>1 4N+20+EA 


SHR 


RB,N 


IIOIOOvO inOlddd 


2 


N=1 2* 
N>1 4N+8 


SHR 


RW,N 


IIOIOOvl inOlddd 


2 




STC 




F9 




2* 


STD 




FD 




2* 


STI 




FB 




2* 


STOS 


BD 


AA 




11 


STOS 


WD 


AB 




11 


SUB 


AL.DATAB 


2CYY 


2 


4' 


SUB 


AX,DATA16 


2D YYYY 


3 


4* 


SUB 


DADDR,DATA8 


80 aalOlbbb 
[DISP] [DISP] YY 


3, 4 or 5 


17+EA 


SUB 


DADDR,DATA16 


lOOOOOal aalOlbbb 
[DISP] [DISP] YY[YY] 


3. 4. 5 or 6 


17+EA 


SUB 


DADDR.RB 


28 aasssbbb 
[DISP] [DISP] 


2. 3 or 4 


16+EA 


SUB 


DADDR.RW 


29 aasssbbb 
[DISP] [DISP] 


2, 3 or 4 


16+EA 


SUB 


RB.DADDR 


2A aadddbbb 
[DISP] [DISP] 


2. 3 or 4 


9+EA 


SUB 


RB,DATA8 


80 inOlddd YY 


3 


4* 


SUB 


RBD.RBS 


2A lldddsss 


2 


3' 


SUB 


RW,DADDR 


2B aadddbbb 
[DISP] [DISP] 


2. 3 or 4 


9+EA 


SUB 


RW,DATA16 


lOOOOOal inOlddd 
YY[YY] 


3 or 4 


4* 


SUB 


RWD.RWS 


2B lldddsss 


2 


3* 
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Table 5-5. 8086 and 8088 Instruction Mnemonics (Cont 


inued) 




Instruction 


Object Code 


Bytes 


Clock 
Periods 


TEST 


AL,DATA8 


A8 YY 


2 


4* 


TEST 


AX,DATA16 


A9 YYYY 


3 


4* 


TEST 


DADDR,DATA8 


F6 aaOOObbb 
[DISP] [DISP] YY 


3. 4 or 5 


11+EA 


TEST 


DADDR,DATA16 


F7 aaOOObbb 
[DISP] [DISP] YYYY 


4, 5 or 6 


11+EA 


TEST 


DADDR,RB 


84 aaregbbb 
[DISP] [DISP] 


2. 3 or 4 


9+EA 


TEST 


DADDR.RW 


85 aaregbbb 
[DISP] [DISP] 


2. 3 or 4 


9+EA 


TEST 


RB,DATA8 


F6 lOOOreg YY 


3 


5* 


TEST 


RBD.RBS 


84 1 1 regreg 


2 


3* 


TEST 


RW,DATA16 


F7 1 1 GOOreg YYYY 


4 


5* 


TEST 


RWD.RWS 


85 11 regreg 


2 


3* 


WAIT 




9B 


1 


3+5n 


XCHG 


AX.RW 


lOOIOreg 


1 


3* 


XCHG 


RB.DADDR 


86 aaregbbb 
[DISP] [DISP] 


2. 3 or 4 


17+EA 


XCHG 


RB.RB 


86 1 1 regreg 


2 


4* 


XCHG 


RW.DADDR 


87 aaregbbb 
[DISP] [DISP] 


2. 3 or 4 


17+EA 


XCHG 


RW,RW 


87 11 regreg 


2 


4* 


XLAT 




D7 


1 


11 


XOR 


AL.DATAS 


34 YY 


2 


4* 


XOR 


AX.DATAie 


36 YYYY 


3 


4* 


XOR 


DADDR,DATA8 


BOaaOIObbb 
[DISP] [DISP] YY 


3. 4 or 5 


17+EA 


XOR 


DADDR,DATA16 


81 aaOIObbb 
[DISP] [DISP] YYYY 


4, 5 or 6 


17+EA 


XOR 


DADDR.RB 


30 aasssbbb 
[DISP] [DISP] 


2, 3 or 4 


16+EA 


XOR 


DADDR.RW 


31 aasssbbb 
[DISP] [DISP] 


2. 3 or 4 


16+EA 


XOR 


RB.DADDR 


32 aadddbbb 
[DISP] [DISP] 


2. 3 or 4 


9+EA 


XOR 


RB,DATA8 


80 imOdddYY 


3 


4* 


XOR 


RBD.RBS 


32 lldddsss 


2 


3* 


XOR 


RW.DADDR 


33 aadddbbb 
[DISP] [DISP] 


2. 3 or 4 


16+EA 


XOR 


RW.DATA16 


81 linOdddYYYY 


4 


4* 


XOR 


RWD.RWS 


33 lldddsss 


2 


3* 
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Table 5-6. 8086 and 8088 Instruction Object Codes 



Object Code 


Mnemonic 


Byte 1 


Byte 2 


Other Bytes 


00 


aasssbbb 


[DISP][DISP] 


ADD 


RBD/DADDR,RBS 


01 


aasssbbb 


[DISP)[DISP] 


ADD 


RWD/DADDR,RWS 


02 


aadddbbb 


[DISP1[DISP] 


ADD 


RBD.DADDR/RBS 


03 


aadddbbb 


[DISPllDISP] 


ADD 


RWD,DADDR/RWS 


04 


YY 




ADD 


AL,DATA8 


05 


YY 


YY 


ADD 


AX,DATA16 


06 






PUSH 


ES 


07 






POP 


ES 


08 


aasssbbb 


[DISP][DISP] 


OR 


RBD/DADDR,RBS 


09 


aasssbbb 


IDISP][DISP] 


OR 


RWD/DADDR,RWS 


OA 


aadddbbb 


[DISPKDISPl 


OR 


RBD.DADDR/RBS 


OB 


aadddbbb 


[DISP][DISP] 


OR 


RWD.DADDR/RWS 


OC 


YY 




OR 


AL,DATA8 


OD 


YY 


YY 


OR 


AX,DATA16 


OE 






PUSH 


CS 


OF 






Not used 


(POP CS) 


10 


aasssbbb 


[DISP][DISP] 


ADC 


RBD/DADDR,RBS 


11 


aasssbbb 


[DISPllDISP] 


ADC 


RWD/DADDR.RWS 


12 


aadddbbb 


[DISPllDISP] 


ADC 


RBD,DADDR/RBS 


13 


aadddbbb 


[DISPHDISPI 


ADC 


RWD.DADDR/RWS 


14 


YY 




ADC 


AL.DATA8 


15 


YY 


YY 


ADC 


AL.DATA1 6 


16 






PUSH 


SS 


17 






POP 


SS 


18 


aasssbbb 


[DISPKDISPl 


SBB 


RBD/DADDR.RBS 


19 


aasssbbb 


[DISP1[DISP1 


SBB 


RWD/DADDR.RWS 


1A 


aadddbbb 


[DISPHDISPI 


SBB 


RBD.DADDR/RBS 


IB 


aadddbbb 


IDISPUDISPI 


SBB 


RWD.DADDR/RWS 


1C 


YY 




SBB 


AL.DATA8 


ID 


YY 


YY 


SBB 


AX,DATA1 6 


IE 






PUSH 


DS 


IF 






POP 


DS 


20 


aasssbbb 


[DISPHDISPI 


AND 


RBD/DADDR.RBS 


21 


aasssbbb 


IDISPHDISP] 


AND 


RWD/DADDR.RWS 


22 


aadddbbb 


[DISPHDISPI 


AND 


RBD.DADDR/RBS 


23 


aadddbbb 


[DISPHDISPI 


AND 


RWD.DADDR/RWS 


24 


YY 




AND 


AL.DATA8 


25 


YY 


YY 


AND 


AX.DATA1 6 


26 






SEG 


ES 


27 






DAA 




28 


aasssbbb 


[DISPHDISPI 


SUB 


RBD/DADDR.RBS 


29 


aasssbbb 


[DISPHDISPI 


SUB 


RWD/DADDR.RWS 


2A 


aadddbbb 


[DISPHDISPI 


SUB 


RBD.DADDR/RBS 


2B 


aadddbbb 


[DISPHDISPI 


SUB 


RWD.DADDR/RWS 


2C 


YY 




SUB 


AL.DATA8 


2D 


YY 


YY 


SUB 


AX.DATA16 


2E 






SEG 


CS 


2F 






DAS 




30 


aasssbbb 


[DISPHDISPI 


XOR 


RBD/DADDR.RBS 


31 


aasssbbb 


[DISP][DISP1 


XOR 


RWD/DADDR.RWS 


32 


aadddbbb 


[DISP][DISP1 


XOR 


RBD.DADDR/RBS 


33 


aadddbbb 


[DISPHDISPI 


XOR 


RWD.DADDR/RWS 


34 


YY 




XOR 


AL.DATA8 


35 


YY 


YY 


XOR 


AX.DATA16 


36 






SEG 


SS 
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Table 5-6. 8086 and 8088 Instruction Object Codes (Continued) 



Object Code 


Mnemonic 


Byte 1 


Byte 2 


Other Bytes 


37 
38 
39 
3A 
3B 
3C 
3D 
3E 


aasssbbb 

aasssbbb 

aadddbbb 

aadddbbb 

YY 

YY 


[DISPKDISP] 
[DISP][DISP] 
[DISP][D1SP] 
[DISP][DISP] 

YY 


AAA 
CMP 
CMP 
CMP 
CMP 
CMP 
CMP 
BEG 


RBD/DADDR.RBS 

RWD/DADDR,RWS 

RBD,DADDR/RBS 

RWD.DADDR/RWS 

AL.DATAS 

AX.DATA16 

DS 


3F 






AAS 




40 






INC 


AX 


41 






INC 


CX 


42 






INC 


DX 


43 






INC 


BX 


44 






INC 


SP 


45 






INC 


BP 


46 






INC 


SI 


47 






INC 


Dl 


48 






DEC 


AX 


49 






DEC 


CX 


4A 






DEC 


DX 


4B 






DEC 


BX 


4C 






DEC 


SP 


4D 






DEC 


BP 


4E 






DEC 


SI 


4F 






DEC 


Dl 


50 






PUSH 


AX 


51 






PUSH 


CX 


52 






PUSH 


DX 


53 






PUSH 


BX 


54 






PUSH 


SP 


55 






PUSH 


BP 


56 






PUSH 


SI 


57 






PUSH 


Dl 


58 






POP 


AX 


59 






POP 


CX 


5A 






POP 


DX 


5B 






POP 


BX 


5C 






POP 


SP 


5D 






POP 


BP 


5E 






POP 


SI 


5F 






POP 


Dl 


60-6F 






Not used 




70 


DISP 




JO 


DISP8 


71 


DISP 




JNO 


DISP8 


72 


DISP 




JB or JNAE or JC 


DISPB 


73 


DISP 




JNB or JAE or JNC 


DISP8 


74 


DISP 




JE or JZ 


DISPB 


75 


DISP 




JNE or JNZ 


DISPB 


76 


DISP 




JBE or JNA 


DISP8 


77 


DISP 




JNBE or JA 


DISP8 


78 


DISP 




JS 


DISPB 


79 


DISP 




JNS 


DISP8 


7A 


DISP 




JP or JPE 


DISP8 


78 


DISP 




JNP or JPO 


DISPB 


7C 


DISP 




JL or JNGE 


DISP8 
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Table 5-6. 8086 and 8088 Instruction Object Codes (Continued) 



Object Code 


Mnemonic 


Byte 1 


Byte 2 


Other Bytes 


7D 


DISP 




JLE or JGE 


DISPB 


7E 


DISP 




JLE or JNG 


DISP8 


7F 


DISP 




JNLE or JG 


DISPB 


80 


aaOOObbb 


[DISP][DISP1 YY 


ADD 


RBD/DADDR,DATA8 


80 


aaOOIbbb 


[DISP][DISP] YY 


OR 


RBD/DADDR,DATA8 


80 


aaOIObbb 


[DISP][DISP] YY 


ADC 


RBD/DADDR,DATA8 


80 


aaOllbbb 


[DISPKDISPl YY 


SBB 


RBD/DADDR,DATA8 


80 


aalOObbb 


[DISP][DISP] YY 


AND 


RBD/DADDR,DATA8 


80 


aalOlbbb 


[DISP][DISP] YY 


SUB 


RBD/DADDR,DATA8 


80 


aallObbb 


[DISPKDISP] YY 


XOR 


RBD/DADDR,DATA8 


80 


aalllbbb 


[DISPKDISP] YY 


CMP 


RBD/DADDR,DATA8 


81 


aaOOObbb 


[DISP] [DISP] YYYY 


ADD 


RWD/DADDR,DATA16 


81 


aaOOIbbb 


[DISP][DISP] YYYY 


OR 


RWD/DADDR,DATA16 


81 


aaOIObbb 


[DISP1[DISP] YYYY 


ADC 


RWD/DADDR,DATA16 


81 


aa011bbb 


[DISP][DISP] YYYY 


SBB 


RWD/DADDR,DATA16 


81 


aalOObbb 


[DISP] [DISP] YYYY 


AND 


RWD/DADDR,DATA16 


81 


aalOlbbb 


[DISP][DISP] YYYY 


SUB 


RWD/DADDR,DATA16 


81 


aallObbb 


[DISP][DISP] YYYY 


XOR 


RWD/DADDR,DATA16 


81 


aalllbbb 


[DISP][DISP] YYYY 


CMP 


RWD/DADDR,DATA16 


82 


aaOOObbb 


[DISP][DISP] YY 


ADD 


RBD/DADDR,DATA8 


82 


xxOOIxxx 




Not used 




82 


aaOIObbb 


[DISP][DISP1 YY 


ADC 


RBD/DADDR,DATA8 


82 


aaOllbbb 


[DISP][DISP] YY 


SBB 


RBD/DADDR,DATA8 


82 


xxlOOxxx 




Not used 




82 


aalOlbbb 


[DISP][DISP] YY 


SUB 


RBD/DADDR,DATA8 


82 


XX 1 lOxxx 




Not used 




82 


aalllbbb 


[DISP][DISP] YY 


CMP 


RBD/DADDR,DATA8 


83 


aaOOObbb 


[DISP] [DISP] YYYY 


ADD 


RWD/DADDR,DATA16 


83 


xxOOIxxx 




Not used 




83 


aaOIObbb 


[DISP1[DISP] YYYY 


ADC 


RWD/DADDR,DATA16 


83 


aa011bbb 


[DISPKDISP] YYYY 


SBB 


RWD/DADDR,DATA16 


83 


xxlOOxxx 




Not used 




83 


aalOlbbb 


[DISP][DISP1 YYYY 


SUB 


RWD/DADDR,DATA16 


83 


XX 1 1 0xxx 




Not used 




83 


aalllbbb 


[DISP] [DISP] YYYY 


CMP 


RWD/DADDR,DATA16 


84 


aasssbbb 


[DISP][DISP] 


TEST 


RBD/DADDR,RBS 


85 


aasssbbb 


[DISP][DISP] 


TEST 


RWD/DADDR,RWS 


86 


aadddbbb 


[DISP1[DISP] 


XCHG 


RBD/DADDR,RBS 


87 


aadddbbb 


[DISP1[DISP] 


XCHG 


RWD/DADDR.RWS 


88 


aasssbbb 


[DISP][DISP] 


MOV 


RBD/DADDR.RBS 


89 


aasssbbb 


[DISP][DISP] 


MOV 


RWD/DADDR.RWS 


8A 


aadddbbb 


[DISP][DISP] 


MOV 


RBD,DADDR/RBS 


8B 


aadddbbb 


[DISP][DISP] 


MOV 


RWD,DADDR/RWS 


8C 


aaOrrbbb 


[DISP] [DISP] 


MOV 


RWD/DADDR,SR 


8C 


xxixxxxx 




Not used 




8D 


aadddbbb 


[DISP][DISP] 


LEA 


RWD.DADDR 


BE 


aaOrrbbb 


[DISP][DISP] 


MOV 


SR.RWD/DADDR 


BE 


xxixxxxx 




Not used 




8F 


aaOOObbb 


[DISP][DISP] 


POP 


RWD/DADDR 


BF 


xxOOIxxx 




Not used 




toBF 


XXl 11 XXX 




Not used 




90 






XCHG 


AX.AX (NOP) 


91 






XCHG 


AX,CX 


92 






XCHG 


AX.DX 


93 






XCHG 


AX.BX 


94 






XCHG 


AX,SP 
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Table 5-6. 8086 and 8088 Instruction Object Codes (Continued) 



Object Code 


Mnemonic 


Bytel 


Byte 2 


Other Bytes 


95 






XCGH 


AX,BP 


96 






XCHG 


AX,SI 


97 






XCHG 


AX.DI 


98 






CBW 




99 






CWD 




9A 


PP 


QQPPQQ 


CALL 


BRANCH.SEGM 


9B 






WAIT 




9C 






PUSHF 




9D 






POPF 




9E 






SAHF 




9F 






LAHF 




AO 


PP 


QQ 


MOV 


AL.LABEL 


A1 


PP 


QQ 


MOV 


AX.LABEL 


A2 


PP 


QQ 


MOV 


LABEL.AL 


A3 


PP 


QQ 


MOV 


LABEL.AX 


A4 






MOVS 


BD.BS 


A5 






MOVS 


WD,WS 


A6 






CMPS 


BD.BS 


A7 






CMPS 


WD.WS 


A8 


YY 




TEST 


AL,DATA8 


A9 


YY 


YY 


TEST 


AX.DATAie 


AA 






STOS 


BD 


AB 






STOS 


WD 


AC 






LODS 


BS 


AD 






LODS 


WS 


AE 






SCAS 


BD 


AF 






SCAS 


WD 


BO 


YY 




MOV 


AL,DATA8 


81 


YY 




MOV 


CL,DATA8 


82 


YY 




MOV 


DL,DATA8 


83 


YY 




MOV 


BL,DATA8 


84 


YY 




MOV 


AH,DATA8 


85 


YY 




MOV 


CH,DATA8 


86 


YY 




MOV 


DH,DATA8 


87 


YY 




MOV 


BH,DATA8 


88 


YY 


YY 


MOV 


AX,DATA16 


89 


YY 


YY 


MOV 


CX,DATA16 


8A 


YY 


YY 


MOV 


DX,DATA16 


8B 


YY 


YY 


MOV 


BX,DATA16 


8C 


YY 


YY 


MOV 


SP,DATA16 


8D 


YY 


YY 


MOV 


BP,DATA16 


8E 


YY 


YY 


MOV 


SI.DATAie 


8F 


YY 


YY 


MOV 


DI,DATA16 


C0-C1 






Not used 




C2 


YY 


YY 


RET 


CS,DATA16 


C3 






RET 




C4 


aadddbbb 


[DISP][DISP] 


LES 


RWD,DADDR 


C5 


aadddbbb 


[DISP][DISP] 


LEA 


RWD,DADDR 


C6 


aaOOObbb 


[DISP][DISP1 YY 


MOV 


DADDR,DATA8 


C6 


xxOOIxxx 




Not used 




to C6 


xxl 1 1xxx 




Not used 




C7 


aaOOObbb 


[DISP][DISP] YYYY 


MOV 


DADDR.DATAI 6 


C7 


xxOOIxxx 




Not used 




toC7 


xxl 11 XXX 




Not used 




C8-C9 






Not used 
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Table 5-6. 8086 and 8088 Instruction Object Codes (Continued) 



Object Code 


Mnemonic 


Bytel 


Byte 2 


Other Bytes 


CA 


YY 


YY 


RET 


CS,DATA16 


CB 






RET 




CC 






INT 


3 


CD 


YY 




INT 


V 


CE 






INTO 




CF 






IRET 




DO 


aaOOObbb 


[OISP][DISP] 


ROL 


RBD/DAD0R,1 


DO 


aaOOIbbb 


[OISP][OISP] 


ROR 


RBD/0ADDR,1 


DO 


aadObbb 


[DISP][0ISP1 


RCL 


RB0/DADDR.1 


DO 


83011 bbb 


[OISP][DISP] 


RCR 


RB0/DAD0R,1 


DO 


aalOObbb 


[0ISP1[DISP] 


SAL or SHL 


RBD/0AD0R,1 


DO 


aalOlbbl 


[DISP][DISP] 


SHR 


RB0/DADDR,1 


DO 


XX 1 lOxxx 




Not used 




DO 


aa111bbb 


[OISPIIOISP] 


BAR 


RBD/0A00R,1 


D1 


aaOOObbb 


[DISP] [DISP] 


ROL 


RW0/DAD0R,1 


D1 


aaOOIbbb 


[DISP][DISP] 


ROR 


RW0/0ADDR,1 


D1 


aaOIObbb 


[OISP][OISP] 


RCL 


RWD/DA00R,1 


D1 


aaOllbbb 


[DISP][OISP] 


RCR 


RW0/0ADDR,1 


D1 


aalOObbb 


[0ISP][0ISP1 


SAL or SHL 


RWD/0ADDR,1 


01 


aalOlbbb 


[0ISP1[DISP] 


SHR 


RWD/DA0DR,1 


Dl 


XX 1 lOxxx 




Not used 




D1 


aalllbbb 


[DISP][OISP] 


SAR 


RW0/DA0DR,1 


D2 


aaOOObbb 


[DISP][DISP] 


ROL 


RBD/DADDR,N 


02 


aaOOIbbb 


[DISPKDISP] 


ROR 


RBD/DADDR,N 


D2 


aaOIObbb 


[DISP] [DISP] 


RCL 


RBO/DADDR,N 


D2 


aaOllbbb 


[DISP] [DISP] 


RCR 


RBD/DADDR,N 


D2 


aalOObbb 


[DISP] [DISP] 


SAL or SHL 


RBO/DADDR,N 


D2 


aalOlbbb 


[DISP][OISP] 


SHR 


RBD/DADOR,N 


D2 


XX 1 lOxxx 








02 


aa 111 bbb 


[DISP] [DISP] 


SAR 


RBD/OADOR,N 


D3 


aaOOObbb 


[DISP1[DISP] 


ROL 


RWO/DADDR,N 


03 


aaOOIbbb 


[DISP][OISP] 


ROR 


RWO/DADDR,N 


03 


aaOIObbb 


[OISP][OISP] 


RCL 


RWD/OAODR,N 


03 


aaOllbbb 


[OISP][DISP] 


RCR 


RWO/OAODR,N 


03 


aalOObbb 


[OISP][DISP] 


SAL or SHL 


RWD/DAODR,N 


03 


aalOlbbb 


[OISP][DISP] 


SHR 


RWD/OAODR,N 


03 


XX 1 lOxxx 




Not used 




03 


aalllbbb 


[OISP][OISP] 


SAR 


RWO/OADDR,N 


04 


OA 




AAM 




05 


OA 




AAD 




06 






Not used 




07 






XLAT 




08-OF 


aaxxxbbb 


[OISP][DISP] 


ESC 


DADDR 


EO 


DISP 




LOOPNE or LOOPNZ 


0ISP8 


El 


DISP 




LOOPE or LOOPZ 


DISP8 


E2 


DISP 




LOOP 


DISP8 


E3 


DISP 




JCXZ 


0ISP8 


E4 


YY 




IN 


AL,PORT 


E5 


YY 




IN 


AX.PORT 


E6 


YY 




OUT 


AL.PORT 


E7 


YY 




OUT 


AX.PORT 


E8 


DISP 


DISP 


CALL 


BRANCH 


E9 


DISP 


DISP 


JMP 


BRANCH 


EA 


PP 


QQ PPQQ 


JMP 


BRANCH.SEGM 


EB 


DISP 




JMP 


BRANCH 
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Table 5-6. 8086 and 8088 Instruction Object Codes (Continued) 





Object Code 






Mnemonic 


Bytel 


Byte 2 


Other Bytes 






EC 






IN 


AL,DX 


ED 






IN 


AX.DX 


EE 






OUT 


AL,DX 


EF 






OUT 


AX,DX 


FO 






LOCK 




F1 






Not used 




F2 






REPNE or REPNZ 




F3 






REP or REPE or REPZ 




F4 






HLT 




F5 






CMC 




F6 


aaOOObbb 


[DISP][DISP] YY 


TEST 


RBD/DADDR,DATA8 


F6 


xxOOIxxx 




Not used 




F6 


aaOIObbb 


[DISP][DISP] 


NOT 


RBD/DADDR 


F6 


aa011bbb 


[DISP1[DISP] 


NEG 


RBD/DADDR 


F6 


aalOObbb 


[DISPIIDISP] 


MUL 


RBD/DADDR 


F6 


aa101bbb 


[DISP][DISP] 


IMUL 


RBD/DADDR 


F6 


aallObbb 


[DISP][DISP] 


DIV 


RBD/DADDR 


F6 


aalllbbb 


[DISP][DISP] 


IDIV 


RBD/DADDR 


F7 


aaOOObbb 


[DISP][DISP] YYYY 


TEST 


RWD/DADDR,DATA1 6 


F7 


xxOOIxxx 




Not used 




F7 


aaOIObbb 


[DISPIIDISP] 


NOT 


RWD/DADDR 


F7 


aa011bbb 


[DISPKDISPl 


NEG 


RWD/DADDR 


F7 


aalOObbb 


[DISPIIDISP] 


MUL 


RWD/DADDR 


F7 


aa101bbb 


[DISPKDISPI 


IMUL 


RWD/DADDR 


F7 


aa110bbb 


[DISP][DISP] 


DIV 


RWD/DADDR 


F7 


aa111bbb 


[DISP][DISP] 


IDIV 


RWD/DADDR 


F8 






CLC 




F9 






STC 




FA 






CLI 




FB 






Sll 




FC 






CLD 




FD 






STD 




FE 


aaOOObbb 


[DISPIIDISP] 


INC 


RBD/DADDR 


FE 


aaOOIbbb 


[DISP][DISP] 


DEC 


RBD/DADDR 


FE 


xxOOIxxx 




Not used 




to FE 


xxl 1 Ixxx 




Not used 




FF 


aaOOObbb 


[DISP][DISP1 


INC 


DADDR 


FF 


aaOOIbbb 


[DISP][DISP] 


DEC 


DADDR 


FF 


aaOIObbb 


[DISP][DISP] 


CALL 


RW/DADDR 


FF 


aa011bbb 


[DISP][DISP] 


CALL 


DADDR.CS 


FF 


aalOObbb 


[DISP][DISP] 


JMP 


RW/DADDR 


FF 


aa101bbb 


[DISP][DISP1 


JMP 


DADDR.CS 


FF 


aa110bbb 


[DISP][DISP1 


PUSH 


DADDR 


FF 


xxl 1 Ixxx 




Not used 
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Table 5-7. 8080A to 8086 Instruction Mapping 





8080A 


Equivalent 8086 | 


Instruction 




nstruction(s) 


IN 


DEV 


IN 


PORT 


OUT 


DEV 


OUT 


PORT 


LDAX 


B* 


MOV 
LODB 


SI.CX 


LDAX 


D 


MOV 
LODB 


SI.DX 


STAX 


B 


MOV 
STOB 


DI,CX 


STAX 


D 


MOV 
STOB 


DI.DX 


MOV 


REG,M 


MOV 


RB.DADDR 


MOV 


M.REG 


MOV 


DADDR,RB 


LDA 


ADDR 


MOV 


AULABEL 


STA 


ADDR 


MOV 


LABEL.AL 


LHLD 


ADDR 


MOV 


BX.DADDR 


SHLD 


ADDR 


MOV 


DADDR,BX 


ADD 


M 


ADD 


AL.DADDR 


ADC 


M 


ADC 


AL,DADDR 


SUB 


M 


SUB 


AL.DADDR 


SBB 


M 


SBB 


AL.DADDR 


ANA 


M 


AND 


AL.DADDR 


XRA 


M 


XOR 


AL.DADDR 


ORA 


M 


OR 


AL.DADDR 


CMP 


M 


CMP 


AL.DADDR 


INR 


M 


INC 


DADDR 


DCR 


M 


DEC 


DADDR 


LXI 


RP,DATA16 


MOV 


RW.DATA16 


MVI 


M.DATA 


MOV 


DADDR.DATAB 


MVI 


REG.DATA 


MOV 


RB.DATA8 


JMP 


ADDR 


JMP 


BRANCH" 


PCHL 




JMP 


BX 


CALL 


ADDR 


CALL 


BRANCH 


CC 


ADDR 


JNB 


next-inst 






CALL 


BRANCH 


CNC 


ADDR 


JB 


next-inst 






CALL 


BRANCH 


CZ 


ADDR 


JNZ 


next-inst 






CALL 


BRANCH 


CNZ 


ADDR 


JZ 


next-inst 






CALL 


BRANCH 


CP 


ADDR 


JS 


next-inst 






CALL 


BRANCH 


CM 


ADDR 


JNS 


next-inst 






CALL 


BRANCH 


CPE 


ADDR 


JPO 


next-inst 






CALL 


BRANCH 


CPO 


ADDR 


JPE 


next-inst 






CALL 


BRANCH 


RET 




RET 







8080A 


Equivalent 8086 


Instruction 


Instruction(s) 


RC 




JNB next-inst 
RET 


RNC 




JB next-inst 
RET 


RZ 




JNZ next-inst 
RET 


RNZ 




JZ next-inst 
RET 


RM 




JNS next-inst 
RET 


RP 




JS next-inst 
RET 


RPE 




JPO next-inst 
RET 


RPO 




JPE next-inst 
RET 


ADI 


DATA 


ADD AL.DATAB 


ACI 


DATA 


ADC AL.DATAB 


SUI 


DATA 


SUB AL.DATAB 


SBI 


DATA 


SBB AL.DATAB 


ANI 


DATA 


AND AL.DATAB 


XRI 


DATA 


XOR AL.DATAB 


ORI 


DATA 


OR AL.DATAB 


CPI 


DATA 


CMP AL.DATAB 


JC 


ADDR 


JB DISPB"* 


JNC 


ADDR 


JNB DISPB 


JZ 


ADDR 


JZ DISPB 


JNZ 


ADDR 


JNZ DISPB 


JP 


ADDR 


JNS DISPB 


JM 


ADDR 


JS DISPB 


JPE 


ADDR 


JPE DISPB 


JPO 


ADDR 


JPO DISPB 


MOV 


d.s 


MOV RBD.RBS 


XCHG 




XCHG DX.BX 


SPHL 




MOV SP.BX 


ADD 


REG 


ADD AL.RBS 


ADC 


REG 


ADC AL.RBS 


SUB 


REG 


SUB AL.RBS 


SBB 


REG 


SBB AL.RBS 


ANA 


REG 


AND AL.RBS 


XRA 


REG 


XOR AL.RBS 


ORA 


REG 


OR AL.RBS 


CMP 


REG 


CMP AL.RBS 


DAD 


RP 


LAHF 

ADD BX.RW 

RCR AL 

SAHF 

RCL AL 

or ADD BX,RW (unlike DAD 

will affect AF.PF.SF, and ZF) 
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Table 5-7. 8080A to 8086 Instruction Mapping (Continued) 



8080A 




Equivalent 8086 




8080A 




Equivalent 8086 


Instruction 




Instruction(s) 




Instruction 




Instruction(s) 


INR REG 




INC RB 


PUSH RP 




PUSH 


RW 


DCR REG 




DEC RB 




PUSH PSW 




LAHF 




CMA 




NOT AL 








PUSH 


AX 


DAA 




DAA 




POP RP 




POP 


RW 


RLC 




ROL AL 




POP PSW 




POP 


AX 


RRC 




ROR AL 








SAHF 




RAL 




RCL AL 




XTHL 




POP 


SI 


RAR 




RCR AL 








XCHG 


BX.SI 


INX RP 




LAHF 
SAHF 
or INC RW (unlike INX - will 




El 
Dl 




PUSH 

STI 

CLI 


SI 






affect AF, PF, SF, and ZF) 




RST N 




CALL 


8*N 


DCX RP 




LAHF 

DEC RW 

SAHF 

or DEC RW (unlike DCX - will 




STC 
CMC 




STC 
CMC 








affect AF, PF, SF, and ZF) 




NOP 
HLT 




XCHG 
HLT 


AX,AX 


*8080A registers map 


into 8086 registers as follows: 

8080A 8086 8080A 

A AL L 
B CH BC 
C CL DE 
D DH HL 
E DL SP 
H BH PC 


8086 

BL 
CX 
DX 
BX 
SP 
IP 






"Addresses on 8086 jumps and calls are adjusted to be self-relative. 








•"Conditional jumps to a location out of the short self-relative range must be implemented by using a reversed- 


sense 


conditional jump around a normal jump to the location, e.g.: 










JC ADDR becomes JNB next-inst 










JMP BRANCH 








Refer to Table 4-4 for a 


complete description of 808A mnemonics shown above. 








Refer to Table 20-4 for 


a complete description of 8086 mnemonics shown above. 
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THE 8088 CPU 

The 8088 is an 8086 microprocessor with an 8-bit Data Bus. The two parts are otherwise identical. Therefore 
we wilt describe differences between the 8088 and the 8086 in the text which follows. 

If you are going to use the 8088, first read the description of the 8086 given at the beginning of this chapter, then note 
differences as described below. 

8088 PROGRAMMABLE REGISTERS AND ADDRESSING MODES 

8088 programmable registers and addressing modes are identical to the 8086 in every way. 

8088 CPU PINS AND SIGNALS 

8088 CPU pins and signals are illustrated in Figure 5-12. As compared to the 8086 pins and signals illustrated 
in Figure 5-3, only pin 34 differs. 

For the 8086, pin 34 outputs BHE. This signal discrinninates b etwe en the high-order byte and the low-order byte on the 
16-bit 8086 Data Bus. Since the 8088 has an 8-bit Data Bus, BHE and associated logic is irrelevant. The 8088 outputs 
maximum mode SSO status at pin 34. 

The lO/M signal has opposite polarity for the 8088, as compared to the 8086. This makes the 8088 compatible 
with the 8085. 

Combining lO/M, DT/R, and SSO, 8088 bus cycles can be decoded as follows: 

lO/M DT/R SSO 












Code segment access 








1 


Memory read 





1 





Memory write 





1 


1 


No operations 


1 








Interrupt acknowledge 


1 





1 


I/O read 


1 


1 





I/O write 


1 


1 


1 


Halt 



Since the 8088 has no BHE signal, nor need for any such signal, the discussion of external memory addressing and BHE 

niv/an f/-.r the RORR lA/ill n/->t anr>l\/ tr. tha flnRfl 



given for the 8086 will not apply to the 8088 
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vcc 

A15 

A16/S3 

A17/S4 

A18/S5 

A19/ S6 

SSO 

MN/MX 

RD 

RQ/5TG, HOLD 

■RQ/StT, HLDA 

LOCK, WR 
IZ lO/M 
^, DT/R" 
50, BER 
QSO, ALE 

asi,w ra 

TEST 

READY 

RESET 



Maximum 
System 
Signals 



IVIinimum 
System 
Signals 



Pin Name 


Description 


Type 


AD0-AD7 


Address/Data Bus 


Bidirectional, Tristate 


A8-A15 


Address Bus 


Output, Tristate 


A16/S3, A17/S4 


Address/Segment Identifier 


Output, Tristate 


A18/S5 


Address/Interrupt Enable Status 


Output, Tristate 


A19/S6 


Address/Status 


Output, Tristate 


SSO 


Status Output 


Output, Tristate 


RD 


Read Control 


Output, Tristate 


READY 


Wait State Request 
Wait for Test Control 


Input 
Input 


TEST 


INTR 


Interrupt Request 


Input 


NMI 


Non-maskable Interrupt Request 


Input 


RESET 


System Reset 


Input 


CLK 


System Clock 


Input 


MN/MX 


= GND for a Maximum System 




So, 5T, Si 


Machine Cycle Status 


Output, Tristate 


RQ/GTO, RQ/GT1 


Local Bus Priority Control 


Bidirectional 


QSO, QS1 


Instruction Queue Status 


Output 


LOCK 


Bus Hold Control 


Output, Tristate 


MN/MX 


= Vcc for a Minimum System 




lO/M 


Memory or I/O Access 


Output, Tristate 


WR 


Write Control 


Output, Tristate 


ALE 


Address Latch Enable 


Output 


DT/R 


Data Transmit/Receive 


Output, Tristate 


DEN 


Data Enable 


Output, Tristate 


INTA 


Interrupt Acknowledge 


Output 


HOLD 


Hold Request 


Input 


HLDA 


Hold Acknowledge 


Output 


Vcc- GND 


Power, Ground 





Figure 5-12. 8088 Pins and Signal Assignments 
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8088 TIMING AND INSTRUCTION EXECUTION 



The 8088 has a 4 byte instruction object code queue; the 8086, in contrast has a 6 byte in- 8088 

struction object code queue. The 8088 will start executing instruction fetch bus cycles to INSTRUCTION 

fill its 4 byte queue as soon as one or more queue bytes are empty. The 8086. in contrast. QUEUE 

will not start pre-fetching instruction object code bytes until two or more of its 6 queue bytes ' 

are empty. The description of bus cycles and queue logic given for the 8086 otherwise applies directly to the 8088. 

8088 MEMORY AND I/O DEVICE ACCESS BUS CYCLES 

Bus cycle timing for the 8088 and the 8086 differ only at the multiplexed Data/Address Bus lines. Timing 
differences are confined to the eight Address Bus lines A8-A15 and may be illustrated as follows: 



T1 



T2 



T3 



T4 



CLK- 



8086 AD0-AD15 
8088 AD0-AD7 



8088 A8-A1 5 



8086 ADO-AD 15 
8088 A00-AD7 






J \__/ — V 



C 



Address Out 



Data Out 



, ^Tl 



Address Out 



n 



C 






Address Out 



Data In 



Apart from the fact that the 8088 has no BHE signal, all timing for signals other than the Data/Address Bus 
identical for the 8086 and the 8088. 
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THE 8088 HALT STATE 

When operating in minimum mode, the 8088 delays the ALE pulse by one clock period as compared to 8086 tim- 
ing. This may be illustrated as follows: 




T3 



TH 



TH 



\_r~\_-rn_j"^ 



HALT 
Halt State logic and timing is otherwise identical for the 8086 and the 8088. 
OTHER 8086 COMPATIBLE 8088 LOGIC 
8086 and 8088 logic is absolutely identical for the following states and logic: 

•The Wait state 

• The Hold state 

• RQ/GT logic 

• Lock logic 

• Wait for test state 

• Processor escape 

• Device reset 

• Interrupt processing 
•Single stepping mode 

THE 8088 INSTRUCTION SET 

The 8086 and 8088 instruction sets, listed in Table 5-4, are identical with the exception of execution times. Since the 
8088 has an 8-bit bus, two bus cycles will have to be executed wherever the 8086 would have executed a single bus 
cycle to fetch 16 bits of data. Table 5-5 provides execution times for the 8086 and the 8088. 
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THE INTEL 8284 CLOCK GENERATOR/DRIVER 

The 8284 Clock Generator/Driver is a standard component that will be present in every 8086 microcomputer 
system. In a multimicroprocessor system, each 8086 microprocessor will have its own 8284 Clock Genera- 
tor/Driver. While one could conceivably have a single 8284 servicing more than one 8086 microprocessor, it will rarely 
make any economic sense to design a system in this fashion. 

Logic implemented on the 8284 Clock Generator/Driver corresponds generally to the block labeled clock logic in 
Figure 5-1. To be completely accurate, however, a small portion of the bus interface logic should also be illustrated as 
provided by the 8284 device. 

Figure 5-13 illustrates 8284 device internal logic. 

The 8284 is manufactured using bipolar technology. It is packaged as an 18-pin DIP. All signals are TTL-level compati- 
ble. 

8284 CLOCK GENERATOR/DRIVER PINS AND SIGNALS 

8284 device pins and signals are illustrated in Figure 5-14. Figure 5-20 illustrates the 8284 device in a single 
8086 microprocessor configuration. 

Signals may be divided between timing and control logic. 

Clock frequency is controlled by a crystal connected across the XI and X2 pins. Clock frequency must be exactly 
three times the required clock period. Since the standard 8086 clock period is 200 nanoseconds, a 15 MHz crystal fre- 
quency is required. 

If an overtone mode crystal is employed, then it must be supported by an external LC network connected to 
TANK to insure oscillation of the overtone frequency. This is standard clock logic practice; for the 8284 it is il- 
lustrated along with other normal connections in Figure 5-15. 

You have the option of connecting a crystal across XI and X2 in order to generate a fundamental frequency, or you can 
input the fundamental frequency via EFI. The lev^l of F/C determines whether an external crystal or a signal in- 
put will provide the fundamental frequency. If F/C is high, then the fundamental frequency is taken from the EFI in- 
put. If F/C is low, then the crystal connected across XI and X2 provides the fundamental frequency. 

Three clock outputs are generated: 

1) CLK is an MOS level signal designed to meet the requirements of the 8086. 

2) PCLK Is a TTL level clock signal, output for support circuits. PCLK runs at half the frequency of CLK. 

3) OSC is an oscillator output running at the crystal or EFI input frequency. 
These timing signals may be illustrated as follows: 




PCLK 
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Res 



XI 

X2 

TANK 



F/C 

EFI 

CSYNC 

RDY1 

AEN1 
AEN2 

RDY2 



XTAL 
OSCILLATOR 



^ 



>> 



t>o^=C> 



->> 



i>o 



l^ 




+3 
SYNC 




RESET 



CK 



+2 
SYNC 



OSC 
CLK 



PCLK 



READY 
SYNC 
LOGIC 



READY 



Figure 5-13. Logic of the 8284 Clock Generator and Driver 
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Pin Name 


Description 


Type 


RESET 


Control Signal Output to 8086 


Output 


RES 


Reset Logic Input 


Input 


RDY1, RDY2 


Wait State Ready Inputs 


Input 


AEN1, AEN2 


Address Enable Qualifiers for RDY1 and RDY2 


Input 


READY 


Control Signal Output to 8086 


Output 


XI, X2 


External Crystal Connections 


Input 


TANK 


Overtone Crystal Tank Circuit Connection 


Input 


EFI 


Alternate Clock Input 


Input 


F/C 


Clock Source Select 


Input 


CLK 


MOS Level Clock Signal to 8086 


Output 


PCLK 


TTL Clock for Peripherals 


Output 


OSC 


Crystal Oscillator Output 


Output 


CSYNC 


Clock Synchronizer 


Input 


Vcc. GND 


Power, Ground 





Figure 5-14. 8284 Clock Generator and Driver Pins and Signal Assignments 
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XTAL 



READY and 

READY enable 

inputs 



VccO 



RESET 



f 



Ho =r"'i 



"R 



lil 



cx 



Jih 



AEN1 
RDY2 
AEN2 



XI 
RDY1 



X2 
OSC 

CLK 

PCLK 

READY 

RESET 



8284 



F/C 

EFI 

CSYNC 

TANK 



r 



OSC 

CLK 

PCLK 

READY 

RESET 






LtI 



X 



Tank circuit used 
with overtone 
crystals only. 



Ct 



Notes: 

1. Cx should be 3 to 10 pF 

2. 

3. 

4, 



Cq (when used) should be 1 to 10 nF 
Cr and Rr determine Reset time constant 
Cj and Lj determine tank frequency; fo = 



Figure 5-15. Nornnal 8284 Clock Generator Circuit 
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SYNCHRONIZING 
MULTI-8086 
CLOCK 
SIGNALS 



In multi-CPU configurations you will probably need to synchronize ail 8086 clock signals. 
You use the CSYNC signal for this purpose. When CSYNC is input high, logic internal to the 
8284 Clock Generator/Driver is stopped. When CSYNC subsequently goes low, clock outputs 
restart. If the same CSYNC signal is input to a number of 8284 devices that receive the same 
EFI input, then all microprocessors in a multi-CPU configuration will be exactly synchronized. 
Appropriate logic is illustrated in Figure 5-16. 

Note that you cannot use individual crystals for 8284 Clock Generator/Drivers that are supposed to be synchronized 
with each; minor variations in cn/stal frequency, which must occur, will quickly distort clock signal synchronization. 
You can use a crystal to generate the fundamental frequency for one 8284 Clock Generator/Driver, then use the OSC 
output of this Clock Generator/Driver as the EFI input to other 8284 Clock Generator/Drivers. 

The 8086 requires its RESET input to be s ynchronized with clock logic. The 8284 will 
receive an asynchronous Reset input at RES and will generate synchronized RESET output, 
which the 8086 requires. Appropriate logic is illustrated in Figure 5-15. Timing is illustrated in 
the data sheets at the end of the chapter. 

The 8284 RES inpu t need not make a sharp transition. The 8284 inputs RES to a Schmit trigger that generates the 
RESET output. RES can make a slow low-to- high transition. 



8086 
RESET 



We have described earlier in this chapter how external logic can extend a bus cycle by inserting 8284 
Waitclock periods between T3 and T4. Figure 5-9 illustrates the READY input that controls Wait WAIT STATE 
states within the 8086 bus controller. As illustrated in Figure 5-9, the 8086 READY input must be LOGIC 
synchronized with the clock signal. The 8284 Clock Generator/Driver outputs an appropriately ^^^— — ^^^ 
synchronized READY signal to the 8086. The 8284 creates its READY output from one of two inputs: RDY1 or 
RDY2.The 8284 has two READY inputs to support MULTIBUS configurations. A single 8086 may connect to two sepa- 
rate System Busses. Memory or I/O devices attached to either bus may wish to create a Wait state within a bus cycle. 
Each System Bus may ther efore have its ow n READY line. In order to arbitrate bus priorities, RDY1 an d RDY 2 have 
companion enable signals AEN1 and AEN2, respectively. The 8284 will respond to RDY1 only when AEN1 is low. 
Similarly, the 8284 will respond to RDY2 only when AEN2 is low. 



AEN1 and AEN2 are general bus priority signals you must generate through your own bus priority arbitration logic. We 
will describe these two signals, and methods of generating them, later in this chapter 
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Master 
Synchronizer 




<< 



CSYNC Input to 
other 8284 devices 

EFI input to 
other 8284 devices 






XI X2 

CSYNC 



8284 



OSC 



Figure 5-16. Clock Synchronization Logic in a Multi-CPU 8086 Configuration 
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THE INTEL 8288 BUS CONTROLLER 

In configurations where the MN/MX signal is low, you must use an 8288 Bus Controller in order to decode the 
SO, SI, and S2 status lines, and thus create System Bus control signals. You can also use the 8288 Bus Con- 
troller in order to connect more than one processor to a single System Bus, or in order to create more than one 
System Bus for a single 8086. 

Although the primary purpose of the 8288 Bus Controller is to decode the three status signals SO, SI, and S2, a 
simple 1-of-8 decoder could accomplish this limited task. The 8288 has these additional capabilities: 

1) The 8288 can generate control signals for a System Bus or an I/O device only bus. 

2) You can float a System Bus's control signals to enable direct memory access, or to arbitrate bus priorities. 

3) The two Write control lines have alternate advanced outputs designed for slow memories or I/O devices. 

4) You can suppress control signals as a means of implementing memory protect logic in multi-bus or 
multimicroprocessor configurations. 

5) The 8288 generates control signals needed by line drivers. 

6) The 8288 generates control signals needed by simple or complex interrupt logic. 

The 8288 Bus Controller is manufactured using bipolar technology. It is packaged as a 20-pin DIP. All signals are TTL- 
level compatible. 

8288 BUS CONTROLLER SIGNALS AND PIN ASSIGNMENTS 

Figure 5-17 illustrates 8288 Bus Controller signals and pin assignments. Figure 5-21 illustrates an 8288 within 
an 8086 microcomputer system. 

Control signals are generated from SO, SI, and S2 as follows: 



s5 


sT 


S2 


8086 


8288 Control Output 











Interrupt acknowledge 


INTA and MCE 








1 


I/O read 


lORC 





1 





I/O write 




lOWC, AlOWC 





1 


1 


Halt 


None 


1 








Instruction fetch 




MRDC 


1 





1 


Memory read 




MRDC 


1 


1 





Memory write 




MWTC, AMWC 


1 


1 


1 


No operation 


None 



5-107 



MRDC 

AMWC 

MWTC 

GND 




Pin Name 


Description 


Type 


SC, 5T,52 


Bus Cycle State Signals 


Input 


CLK 


TTL Clock Signal 


Input 


A£N 


Bus Priority Control/Enable 


Input 


CEN 


Comnnand Enable 


Input 


lOB 


Mode Control 


Input 


MRDC 


Memory Read Strobe 


Output, Tristate 


MWTC 


Memory Write Strobe 


Output, Tristate 


AMWC 


Early Memory Write Strobe 


Output, Tristate 


IORC 


I/O Read Strobe 


Output, Tristate 


lOwd 


I/O Write Strobe 


Output, Tristate 


AlOWC 


Early I/O Write Strobe 


Output, Tristate 


IhJtA 


Interrupt Acknowledge 


Output, Tristate 


MCE/PDEN 


Cascade/Peripheral Data Enable 


Output 


ALE 


Address Latch Enable 


Output 


DT/R 


Data Direction Control 


Output 


DEN 


Data Buffer Enable 


Output 


Vcc. GND 


Power, Ground 





Figure 5-17. 8288 Bus Controller Pins and Signal Assignments 
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8288 and 8086 control signal timing is essentially the same. For details, see the data sheets given at the end of this 
chapter. 

If you look again at the Read and Write bus cycle timing descriptions given earlier in this chapter 
for the 8086 you will see that Read control signals pulse low approximately one clock period 
earlier than Write control signals. The 8288 creates two alternate Write control signals whose 
timing is the same as the Read control signals. These alternative Write control signals are re- 
ferred to as advanced Write control signals, because they go low one clock pulse in advance of the 
standard Write control signals. 

We can thus summarize 8288 System Bus control signals as follows: 



8288 

ADVANCED 

WRITE 

CONTROL 

SIGNALS 



MRDC is the memory read control. 



MWTC is the memory write control. 



AMWC is a memory write control whose timing conforms to MRDC. 

INTA is a memory read control signal that is output during the two interrupt acknowledge bus cycles. 

lORC is an I/O device read control signal. 



lOWC is an I/O device write control signal. 



AlOWC is an alternative I/O device write control signal with timing that conforms to lORC. 



Devices connected to a bus are likely to use lOWC and MWTC or AlOWC and AMWC, but not all four signals. That is, 
you will use either the normal write control signals or you will use the advanced write control signals. 

Ail 8288 control signals are tristate. They can be disabled and thus disconnected from the System Bus. 

You liave two control options that modify the control signal logic of the 8288 Bus Controller. 

Using the lOB pin, you can operate the 8288 device in I/O bus mode or in System Bus mode. 

Using the CEN pin, you can suppress control signals. 

Let us examine each of these capabilities in turn. 



When the lOB pin rec eive s a high input, the 8288 Bus Contr oller generates an I/ O bu s. lOB h igh 8288 I/O 
floats MR,DC, MWTC, and AMWC all of the time but outputs INTA, lORC, lOWC, and AlOWC. In BUS MODE 
I/O bus mode, these four I/O control signals cannot be floated. Since the four I/O control lines will l^— — — — 
always be active, it is assumed that the I/O bus generated by an 8288 is a logic bus. You cannot share this local I/O bus 
with another microprocessor. 



The 8288 I/O bus has two control signals, PDEN and DT/R, which drive I/O ports and line drivers. DT/R, which we have 
described for the 8086, is used to control a bidirectional bus driv er Wh en high, DT/R puts the bus driver i n outp ut 
mode, while when low, DT/R puts the bus driver in input mode. PDEN pulses low as a data enable signal, PDEN is 
equivalent to DEN, the standard bus data enable signal output by the 8086. 

When lOB is low, a n ormal Sy stem Bus is generated. All seven control signals are active; however, AEN is a bus enable 
control (much as the BUSEN input is used by the 8228 Bus Controller in an 8080A system). 

AEN is inactive when lOB is high and an I/O bus is being generated. AEN is active only when lOB is low and a System 
Bus is generated. 

When lOB is low and AEN is high, all contro l sign als are floated. When lOB is low and AEN is low, control signals are 
connected to the System Bus. You will use AEN to implement bus priority arbitration logic, or direct memory access 
logic, as described later in this chapter 

CEN is used to disable, but not float, control signals. CEN can be used when an 8288 is 
generating a System Bus or an I/O bus. CEN will normally be high. When CEN is low, control 
signals are inactive. CEN does not float signals; it just disables the logic that might other- 
wise have made a control signal pulse low. 

Table 5-8 summarizes the effect of lOB and CEN on control signals generated by the 8288 
Bus Controller. 



8288 BUS 
CONTROLLER 
MEMORY 
PROTECT 
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Table 5-8. Effect of lOB. CEN, and AEN on Control Signals Output by the 8288 Bus Controller 



Control Unit 


Effect on Control Output 


lOB 


CEN 


AEN 


INTA. 






1 


lORC, lOWC, AlOWC 


IVIRDC, IVIWTC, AlVIWC | 


Mode 


Floated? 


Active? 


IVIode 


Floated? 


Active? 







1 
1 
1 
1 





1 
1 




1 
1 



1 


1 



1 



1 


System 
System 
System 
System 

I/O 

I/O 

I/O 

I/O 


Floated 

Floated 

Connected 

Connected 

Floated 

Floated 

Connected 

Connected 


Active 
Inactive 
Active 
Inactive 
Active 
Active 
Active 
Active 


System 
System 
System 
System 
Not Used 
Not Used 
Not Used 
Not Used 


Floated 
Floated 
Connected 
Connected 
Floated 
Floated 
Floated 
Floated 


Active 
Inactive 

Active 
Inactive 
Inactive 
Inactive 
Inactive 
Inactive 



The CEN control enables mennory mapping. Here are some possibilities: 

1) In multi-bus configurations, one block of memory addresses may access mennory on two or more busses. In order to 
avoid contentions, you can use the CEN signal to selectively disable busses so that only one bus will actually res- 
pond when the 8086 accesses duplicated memory addresses. 

2) Privileged memory is frequently present in large microcomputer systems. Privileged memory is likely to become 
more common in microcomputer systems as they grow larger. Privileged memory is memory that can be accessed 
only under special circumstances. Frequently, system programs are run out of privileged memory, while applica- 
tion programs are run out of non-privileged memory. This prevents errors in application programs from destroying 
system programs; it also prevents unauthorized access of reserved memory spaces. 

DT/R and DEN, the two standard buffer control signals, are generated by the 8288 when it is creating a normal 
System Bus. These two control signals, when generated by the 8288 Bus Controller, are identical in form and purpose 
to the signals that the 8086 creates. DT/R determines the data direction for bidirectional buffers, while DEN is a latch- 
ing strobe. 



The 8288 generates two interrupt control sign als: IN TA and MCE. INTA is active on a 
System Bus or an I/O Bus. MCE shares a pin with PDEN and is active only on a System Bus. 

As we discussed earlier in this chap ter, th e 8086 executes two bus cycles when acknowle dging 
an interrupt. During each bus cycle, INTA is output as a low read pulse. On the second low INTA 
pulse, the acknowledged device must return an 8-bit code, which the 8086 uses as an interrupt 



8288 BUS 
CONTROLLER 
INTERRUPT 
SIGNALS 



vector. The INTA control signal generated by the 8288 Bus Controller is identical to the 8086 INTA control signal and 
serves the same purpose, on a System Bus or an I/O Bus. The MCE control signal has been added for use in large 8086 
microcomputer systems that use a variation of the 8259A Priority Interrupt Control Unit. When you have a master 
8259A Priority In terrup t Control Unit and slave 8259A Priority Interrupt Control Units, you will use MCE as a control to 
the master, while INTA becomes a control to slaves. The 8086 version of the 8259A Priority interrupt Control Unit is not 
described in this chapter. 
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THE 8282/8283 8-BIT INPUT/OUTPUT LATCH 

These are simple unidirectional 8-bit latch buffers. The 8283 inverts inputs in order to create outputs: the 8282 
does not. That is the only difference between these two devices. 

Both devices have three-state outputs. When a device is not selected, its outputs are floated. 

These devices are manufactured using bipolar technology. All signals are TTL-level compatible. Outputs have a high 
drive capability, as defined in the data sheets at the end of this chapter. The devices are packaged as 20-pin DIPs. 

THE 8282/8283 INPUT/OUTPUT LATCH PINS AND SIGNAL ASSIGNMENTS 

Figure 5-18 illustrates the pins and signal assignments for the 8282 and 8283 8-bit input/output latches. 

Data must be input at DI0-D17. 

When STB is high, the internal latches appear transparent and data on the output pins track data on the input pins. The 
transition from high to low of STB latches the data. The outputs remain stable while STB is low. 

Data that is latched internally is output when OE is low. The 8282 outputs data unaltered, while the 8283 inverts 
the data. 

Were you to simply ground OFand tie STB to +5 V, the 8282 or 8283 I/O ports will function as simple bus drivers. The 
outputs will continuously track the inputs, but will support heavier signal loads. 

If you tie STB high, but use the low OE" pulse, then input data is constantly available but outputs only become valid 
while OE is low. Timing may be illustrated as follows: 



DI0-DI7 



I 



OE 



DO0-DO7 



n 



5 
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8282 

or 
8283 




Pin Name 


Descriiition 


Type 


DI0-DI7 


Data Input 


Input 


DO0-DO7 


Data Output 


Output, Tristate 


T5E 


Output Enable 


Input 


STB 


input Data Strobe 


Input 


Vcc- GND 


Power, Ground 





Figure 5-18. 8282 and 8283 Input/Output Latch Pins and Signal Assignments 



When the Strobe and Output Enable signal are both active, I/O port logic may be illustrated as follows: 



DI0-DI7 



STB 



Latches 




X 



OE 



DO0-DO7 



t 
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8286 
or 



8287 




Pin Name 


Description 


Type 


A0-A7 


Local Bus 


Bidirectional, Tristate 


B0-B7 


System Bus 


Bidirectional, Tristate 


OE 


Output Enable 


Input 


T 


Direction Select 


Input 


Vcc. GND 


Power, Ground 





Figure 5-19. 8286 and 8287 Bidirectional Bus Transceiver Pins and Signal Assignnnents 



THE 8286/8287 8-BiT BIDIRECTIONAL BUS TRANSCEIVERS 

These two devices are used to buffer bidirectional lines on a System Bus. The 8286 transmits data unaltered, 
while the 8287 inverts the data. The two devices are otherwise the same. 

The 8286 and 8287 bidirectional bus drivers are manufactured using bipolar technology. All pins are TTL-level com- 
patible. The devices are packaged as 20-pin DIPs. 

8286 AND 8287 BIDIRECTIONAL BUS TRANSCEIVER PINS AND SIGNAL 
ASSIGNMENTS 

Figure 5-19 illustrates pins and signal assignments for the 8286 and 8287 bidirectional bus drivers. 

A0-A7 constitute eight parallel data lines that connect with the microprocessor Data/Address Bus. B0-B7 con- 
stitute eight equivalent lines that connect with the System Bus. System Bus outputs have a higher line drive 
capability (as defined in the data sheets at the end of this chapter); othenwise, there is no difference between the two 
busses. 

When the T input is low, data arriving at the B pins is output via the A pins. When T is high, data arriving at the A 
pins are output via the B pins. The actual data transfer occurs only while OE is low. When used as an 8086 Data 
Bus transceiver, T should be connected to DT/R and OE connected to DEN. 
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SOME 8086 MICROPROCESSOR BUS CONFIGURATIONS 

We are now going to look at some 8086 microprocessor bus configurations. 

The flexibility of the 8086 gives rise to such a bewildering array of system configuration possibilities that a 
whole book could be written on the subject. We are going to fulfill the more limited objective of identifying 
possibilities. 

Figure 5-20 illustrates the simplest case. Here we are using the 8086 to generate a simple microcomputer system. 
Addresses taken off the bidirectional 8086 Data/Address Bus are unidirectional. We therefore use 8282 I/O ports to 
latch addresses of the 8086 Data/Address Bus. In Figure 5-20 we show just two 8282 I/O ports generating a 16-line 
Address Bus. Address lines A16 through A19 are wasted. By adding one more 8282 I/O port to the logic in Figure 
5-37, you could include the four missing Address Bus lines. 

In Figure 5-20, we ground the Output Enable inputs of the 8282 I/O ports; the Address Bus will therefore never be 
floated. We use the 8086 ALE pulse to strobe addresses into the 8282 I/O ports. 

Since the Data Bus is bidirectional, we use 8286 bidirectional Bus Transceivers in order to create a separate Data Bus 
from the 8086 Address/Da ta Bu s. Two 8286 bidirectional Bus Transceiversjre required to create the 16-line Data Bus. 
We can use the DT/R and DEN outputs of the 8086 as the 8286 T and CS inputs. 

We can now illustrate timing for creation of the Address Bus and Data Bus during a read bus cycle, as follows: 



CLK 



ADO-AD 15 



BHE 



ALE 



M/IO 



DT/R 



DEN 



8282 Dl 



8282 DO 



8286 B 



8286 A 




{= ADO- 
'ADI 5) 
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vcc 



MN/MX 



ADO 



8086 



vcc- 




ADO 



AD7 



8282 



ST^ 



DT/R 



DEN 



V 



OE 



8282 



OE 



8286 



OE 



8284 



XI X2 



RDY1 



AEN2 



AEN1 



F/C 



•+■ 



f i 



■M/ID 

■ Tnta 

RD 

WR 

•AG 

A7 

■ A8 
A15 

BHE 



DO 
D7 
D8 
D15 



READY 
PCLK 



Figure 5-20. Generating a System Bus for a Simple 8086 Configuration 

The simple system illustrated in Figure 5-20 will not make use of the dual READY clock logic. A single READY input is 
connected toRDYl, and both of the READY enables are grounded. Thus, the 8086 READY input will be created directly 
from the 8284 RDY1 input. 

Figure 5-21 illustrates a slightly more complex 8086 microcomputer configuration. Figure 5-21 uses an 8288 
Bus Controller to generate System Bus control signals. The DEN, DT/R, and ALE control outputs, which in Figure 
5-20 were generated by the 8086 microprocessor, are now generated by the 8288 Bus Controller. 

Asa stand-alone microcomputer configuration. Figure 5-21 offers little or no advantage over Figure 5-20. In a single 
bus, single 8086 microcomputer configuration, there is no compelling reason to use the 8288 Bus Controller. All it does 
is add an extra component to the system without offering any significant logic enhancement. 
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GND_jMN^ 



vcc 



I 



o • • » ► 

T 



so 



SI 



S2 



GND 



I OB 



DEN 



/DO 



8086 



^HE 



AD8 



AD15 



DT/W 



ALE 



8288 



ADO 



AD7 



8282 



* 



STB. 



ADS 



ADI^ 



8282 



ADO. 



AD7 



OE 



8286 



OE 



AD15 



8286 



8284 



RDY1 



AEN2 



AEN1 
I * _ # 

F/C 






-*-MRDC 



-+-MWTC 
-»-TORC 



-^lOWC 



-»-A0 



-»-A8 



-»-BHE 



DO 
■D7 



-»-D8 
■*-D15 



READY 
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Figure 5-21. Generating a System Bus in an 8086 Microcomputer System Using 
an 8288 Bus Controller 
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DATA SHEETS 



This section contains specific electrical and timing data for the following devices: 
8086 CPU 
8088 CPU 

8282/8283 I/O Ports 
8284 Clock Generator 
8286/8287 Bidirectional Bus Drivers 
8288 Bus Controller 
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8086/8086-2/8086-4 





ABSOLUTE MAXIMUM RATINGS* 

Amhianf Tf^mnoratiira llnrii>r Rias O'C to70'C 


NOTICE: Stresses above those listed under "Absolute Maximum Ratinoii 




Slorage Temperature - 65°C to + 150*C may cause permanent damage to the device. This is a stress rating only and 

V H r>n &nu P'n uuith functional operation ot the device at these Or any other conditions above 
voltage on Any Kin Wltn 1^,^,^^ indicated in the operational sections of this specification Is not 

Respect to Ground — 1 to -i- TV ■. r._j = ._ .i ■,.> •. —.—^ j:.-. •_. . i—. 


Pnwnr r^i<$sinatinn 




2.5 Watt periods mav affect device reliability. 




D.C. CHARACTERISTICS 

8086: Ta = 0*C to 70 'C, Vcc = 5V ± 10% 
B086-2/8086-4: Ta=0"'C to ZCC, Vcc = 5V ±5% 






Symbol 


Parameter 


Min. 


Max. 


units 


Test Condlllon* 




V|L 


Input Low Voltage 


-0.5 


■^0.8 


V 




V,H 


Input High Voltage 


2.0 


Vcc+0.5 


V 




Vol 


Output Low Voltage 




0.45 


V 


loL= 2.0 mA 


VOH 


Output High Voltage 


2.4 




V 


Iqh = - 400 mA 


'cc 


Power Supply Current 
8086/8086-4 
8086-2 




340 
350 


mA 
mA 


Ta = 25-C 


lu 


Input Leakage Current 




±10 


mA 


OV<V,N<Vcc 


Ilo 


Output Leakage Current 




±10 


mA 


0.45V < VouT < Vcc 


Vol 


Clock Input Low Voltage 


-0.5 


-hO.6 


V 




VCH 


Clock Input High Voltage 


3.9 


Vcc+1.0 


V 




C|N 


Capacitance of Input Buffer 
(All input except 
ADo-ADis, RQ/GT) 




15 


PF 


fc=1 MHz 


C,o 


Capacitance of I/O Buffer 
(AD0-AD15, RQ/GT) 




15 


PF 


fc=1 MHz 









Data sheets on pages 5-D2 through 5-D29 are reprinted by permission of Intel Corporation. 
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8086/8086-2/8086-4 



A.C. CHARACTERISTICS 

8086: Ta = O'C to 70'C, Vcc = 5V ± 10% 
8086-2/8086-4: Ta = 0*C to 70'C, Vcc = 5V ± 5% 

8086 MINIMUM COMPLEXITY SYSTEM (Figures 8, 9, 12, 15) 
TIMING REQUIREMENTS 



Symbol 


P«ram«t«r 


8086(808«-4 


8086-2 (Prallmlnary) 


Units 


Test Conditions 






MIn. 


Max. 


MIn. 


Max. 






TCLCL 


CLK Cycle Period - 8086 
-8086-4 


200 
250 


soo 

500 


125 


500 


ns 




TCLCH 


CLK Low Time 


(2/1 TCLCL)- 15 




(% TCLCL) -15 




ns 


TCHCL 


CLK High Time 


(Vi TCLCL) + 2 




(Vi TCLCL) +2 




ns 


TCH1CH2 


CLK Rise Time 




10 




10 


ns 


From 1.0V to 3.5V 


TCL2CL1 


CLK Fall Time 




10 




10 


ns 


From 3.5V to 1.0V 


TDVCL 


Data In Setup Time 


30 




20 




ns 




TCLDX 


Data In Hold Time 


10 




10 




ns 


TR1VCL 


ROY Setup Time into 8284 (See Notes 1, 2) 


35 




35 




ns 


TCLR1X 


ROY Hold Time into 8284 (See Notes 1, 2) 












ns 


TRYHCH 


READY Setup Time into 8086 


(2/^ TCLCL)- 15 




(% TCLCL) -15 




ns 


TCHRYX 


READY Hold Time into 8086 


30 




20 




ns 


TRYLCL 


READY Inactive to CLK (See Note 3) 


-8 




-8 




ns 


THVCH 


HOLD Setup Time 


35 




20 




ns 


TINVCH 


INTR, NMI, TEST Setup Time (See Note 2) 


30 




15 




ns 



TIMING RESPONSES 



Symbol 


Paramator 


8086/8086-4 


8086-2 (Preliminary) 


Units 


Test Conditions 






MIn. 


Max. 


MIn. 


Max. 






TCLAV 


Address Valid Delay 


10 


110 


10 


60 


ns 


Cl= 20-100 pF (or 
all 8086 Outputs 
(In addition to 
8086 self-load) 


TCLAX 


Address Hold Time 


10 




10 




ns 


TCLAZ 


Address Float Delay 


TCLAX 


80 


TCLAX 


50 


ns 


TLHLL 


ALE Width 


TCLCH-20 




TCLCH-10 




ns 


TCLLH 


ALE Active Delay 




80 




50 


ns 


TCHLL 


ALE Inactive Delay 




85 




55 


ns 


TLLAX 


Address Hold Time to ALE Inactive 


TCHCL-10 




TCHCL-1C 




ns 


TCLDV 


Data Valid Delay 


10 


110 


10 


60 


ns 


TCHDX 


Data Hold Time 


10 




10 




ns 


TWHDX 


Data Hold Time After WR 


TCLCH-30 




TCLCH-30 




ns 


TCVCTV 


Control Active Delay 1 


10 


110 


10 


70 


ns 


TCHCTV 


Control Active Delay 2 


10 


110 


10 


60 


ns 


TCVCTX 


Control Inactive Delay 


10 


110 


10 


70 


ns 


TAZRL 


Address Float to READ Active 












ns 


TCLRL 


RQ Active Delay 


10 


165, 


10 


100 


ns 


TCLRH 


RC Inactive Delay 


10 


150 


10 


80 


ns 


TRHAV 


RO Inactive to Next Address Active 


TCLCL-45 




TCLCL -40 




ns 


TCLHAV 


HLDA Valid Delay 


10 


160 


10 


10O 


ns 


TRLRH 


RQ V)/idth 


2TCLCL-75 




2TCLCL-50 




ns 


TWLWH 


WR Width 


2TCLCL-60 




2TCLCL-40 




ns 


TAVAL 


Address Valid to ALE Low 


TCLCH-60 




TCLCH-40 




ns 



NOTES: 1. Signal at 8284 shown tor reference only. 

2. Setup requirement (or asynchronous signal only to guarantee recognition at next CLK. 

3. Applies only to T2 state. (8 ns Into T3) 
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8086/8086-2/8086-4 



CLK (8284 Output) 



BHE«7, AiilSt-AiilSj 



^ TCLCL ►TCH1CH2»] U- -i^ [— TCL2CL1 / 



ROY (8284 Input) 
SEE NOTE 4 



READY (8088 Input) 



READ CYCLE 

(NOTE 1) 

(WR.fRTA-VoH) 



t 



X 



/ 



BhI, Ai»./ „ 



\ 



TAVAl 
TLLAX- 



X 



— TCHCTV TCLRL 



Ti Tw 



}C 



V|H 

Vll 
TRYLCL 



:x: 



»- TCLCH — 



1— ^CLRIX 



/ 



r 
J' 



^ 



X 



/ — 
/ 



\ 



\ 





c 



Figure 8. 8086 Bus Timing — IMinimum Mode System 
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8086/8086-2/8086-4 



SH&S;, Ait/St-A,|/S) 



WRITE CYCLE 
(NOTE 



INTA CYCLE 
(NOTES 1 ft 3) 

RC.Wfi.VoM 
SHE -Vol) 



SOFTWARE HALT - 
6ENR5.ifH,INTS VOH 




SOFTWARE HALT 



NOTES: 1. ALL SIQNALS SWITCH BETWEEN Vqh AND Vol UNLESS OTHERWISE 
SPECIFIED. 

2. ROY IS SAMPLED NEAR THE END OF Tj, Tj. Tw TO DETERMINE IF Tw 
MACHINES STATES ARE TO BE INSERTED. 

3. TWO INTA CYCLES RUN BACKTOBACK. THE SOU LOCAL AODR/OATA BUS IS 
FIOATINQ DURING BOTH INTA CYCLES. CONTROL SIGNALS SHOWN FOR 
SECOND INTA CYCLE. 

4. SIGNALS AT tiU ARE SHOWN FOR REFERENCE ONLY. 

t. ALL TIMING MEASUREMENTS ARE MADE AT 1.SV UNLESS OTHERWISE 
NOTED. 



Figure 9. 8086 Bus Timing — Minimum Mode System (cont'd) 
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8086/8086-2/8086-4 



8086 MAX MODE SYSTEM (USING 8288 BUS CONTROLLER) (Figures 10-14) 
TIMING REQUIREMENTS 




Symbol 


Parameter 


808W8086-4 


8086-2 (Preliminary) 


Unit* 


Tom Condition* 








MIn. 


Max. 


Min. 


Max. 






TCLCL 


CLK Cycle Period - 8086 
-8086-4 


200 
250 


500 
500 


125 


500 


ns 


TCLCH 


CLK Low Time 


('A TCLCL) -15 




(2/i TCLCL)- 15 




ns 


TCHCL 


CLK High Time 


(Vi TCLCL) + 2 




(W TCLCL) + 2 




ns 


TCH1CH2 


CLK Rise Time 




1C 




10 


ns 


From 1.0V to 3.5V 


TCL2CL1 


CLK Fall Time 




10 




10 


ns 


From 3.5V to 1.0V 


TDVCL 


Data In Setup Time 


30 




20 




ns 




TCLDX 


Data In Hold Time 


10 




10 




ns 


TR1VCL 


RDY Setup Time into 8284 (See Notes 1, 2) 


35 




35 




ns 


TCLR1X 


RDY Hold Time into 8284 (See Notes 1, 2) 












ns 


TRYHCH 


READY Setup Time into 8086 


(2/! TCLCL)- 15 




(2/i TCLCL)- 15 




ns 


TCHRYX 


READY Hold Time Into 8086 


30 




20 




ns 


TRYLCL 


READY Inactive to CLK (See Note 4) 


-8 




-8 




ns 


TINVCH 


Setup Time for Recognition 
(INTR, NMI, TEST) (See Note 2) 


30 




15 




ns 


TGVCH 


RQ/GT Setup Time 


30 




15 




ns 


TCHGX 


RO Hold Time into 8086 


40 




30 




ns 


TIMING RESPONSES 














Symbol 


Parameter 


8086/8086-4 


8086-2 (Preliminary) 


Unit* 


Teat Condltlont 








IMIn. 


Max. 


Min. 


Max. 




Cl= 20-100 pF for 
all 8086 Outputs 
(In addition to 
8086 self-load) 


TCLML 


Command Active Delay (See Note 1) 


10 


35 


10 


35 


ns 


TCLMH 


Command Inactive Delay (See Note 1) 


10 


35 


10 


35 


ns 


TRYHSH 


READY Active to Status Passive (See Note 3) 




110 




65 


ns 


TCHSV 


Status Active Delay 


10 


110 


10 


60 


ns 


TCLSH 


Status Inactive Delay 


10 


130 


10 


70 


ns 


TCLAV 


Address Valid Delay 


10 


110 


10 


60 


ns 


TCLAX 


Address Hold Time 


10 




10 




ns 


TCLAZ 


Address Float Delay 


TCLAX 


80 


TCLAX 


50 


ns 


TSVLH 


Status Valid to ALE High (See Note 1) 




15 




15 


ns 


TSVMCH 


Status Valid to MCE High (See Note 1) 




15 




15 


ns 


TCLLH 


CLK Low to ALE Valid (See Note 1) 




15 




15 


ns 


TCLMCH 


CLK Low to MCE High (See Note 1) 




15 




15 


ns 


TCHLL 


ALE Inactive Delay (See Note 1) 




15 




15 


ns 


TCLMCL 


MCE Inactive Delay (See Note 1) 




15 




15 


ns 


TCLDV 


Data Valid Delay 


10 


110 


10 


60 


ns 


TCHDX 


Data Hold Time 


10 




10 




ns 


TCVNV 


Control Active Delay (See Note 1) 


5 


45 


5 


45 


ns 


TCVNX 


Control Inactive Delay (See Note 1) 


10 


45 


10 


45 


ns 


TAZRL 


Address Float to Read Active 












ns 


TCLRL 


RD Active Delay 


10 


165 


10 


100 


ns 


TCLRH 


RD Inactive Delay 


10 


150 


10 


80 


ns 


TRHAV 


RD Inactive to Next Address Active 


TCLCL-45 




TCLCL-40 




ns 


TCHDTL 


Direction Control Activu Delay (See Note 1) 




50 




50 


ns 


TCHDTH 


Direction Control Inactive Delay (See Note 1 ) 




30 




30 


ns 


TCLGL 


GT Active Delay 





85 





SO 


ns 


TCLGH 


ST Inactive Delay 





85 





50 


ns 


TRLRH 


RD W/idth 


2TCLCL-75 




2TCLCL-50 




ns 




NOTES: 1. Signal at 8284 or 8288 shown for reference only. 

2. Setup Msquirement for asynchronous signal only to guarantee recognition at ne 

3. Applies only to T3 and wait states. 

4. Applies only to T2 state (8 ns into T3). 


xt CLK. 
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8086/8086-2/8086-4 



Si,ST,Si (EXCEPT HALT) 



BHES;, Ai|/St-Ai(fSa 



ALE (S2M OUTPUT) 



ROY (MM INPUT) 



READY (MM INPUT) 



'v 



X 



TSVLH-H 
TCLLH^ 



/ 



READ CYCLE ^clav- 

ADij-AOo 



X 



\ 



X 



— \/ — 



TCH1CH2— I U- — j I-TCL2CL1 t„ 
,_„ -• TCLC L 'I ''^ 

-- ► TCHCL --TCLCI 



7 ''/a// a// '^^'^ **°^^ *' 



^BK 



TCHOTL -^ 



\ 



«2M OUTPUTS 
SEE NOTES S,6 
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)C 
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X 
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Figure 10. 8086 Bus Timing — iMaximum Mode System (Using 8288) 
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8086/8086-2/8086-4 



Sj.S^.S; (EXCEPT HALT) 



WRITE CYCLE 



8288 OUTPUTS 
SEE NOTES 5.6 



AMWC OR AlOWC 



MWTC OR lOWC 



INTA CYCLE 



MCEJ 



OEN 




NOTES: 1. ALL SIGNALS SWITCH BETWEEN Voh ANO Vql UNLESS OTHERWISE 
SPECIFIED. 

2. ROY IS SAMPLED NEAR THE END OF Tj, Ti. Tw TO DETERMINE IF Tw 
MACHINES STATES ARE TO BE INSERTED. 

3. CASCADE ADDRESS IS VALID BETWEEN FIRST AND SECOND INTA CYCLE. 

4. TWO INTA CYCLES RUN BACKTOBACK. THE loas LOCAL ADDR/DATA BUS IS 
FLOATING DURING BOTH INTA CYCLES. CONTROL FOR POINTER ADDRESS 
IS SHOWN FOR SECOND INTA CYCLE. 

5. SIGNALS AT 1284 OR 8288 ARE SHOWN FOB REFERENCE ONLY. 

*' THE IS S UANC E OF THE 8218 COMMAND ANO CONTROL SIGNALS (HnSC, 

HWTC, AiSWe. iSfiC, iSwC, AlOWC. i?JTA AND DEN) LAGS THE ACTIVE HIGH 
8288 CEN. 

7. ALL TIMING MEASUREMENTS ARE MADE AT 1.SV UNLESS OTHERWISE 
NOTED. 

8. STATUS INACTIVE IN STATE JUST PRIOR TO T4. 



Figure 11. 8086 Bus Timing — Maximum Mode System (Using 8288) (cont.) 
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8086/8086-2/8086-4 



], — TINVCH (SM now 1] 



NOTE: 1 SETUP REQUIBEMENTS FOR ASYNCHRO- 
NOUS SIGNALS ONLY TO GUARANTEE RECOGNITION 
AT NEXT CLK 



Figure 12. Asynchronous Signal Recognition 
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Figure 13. Bus Locl( Signal Timing (Maximum Mode Only) 
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Figure 14. Request/Grant Sequence Timing (Maximum Mode Only) 
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Figure 15. Hold/Hold Acknowledge Timing (Minimum Mode Only) 
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8088 



ABSOLUTE MAXIMUM RATINGS* 

Ambient Temperature Under Bias 0*C to70°C 

Storage Temperature - 65 'C to + 150°C 

Voltage on Any Pin with 

Respect to Ground - 1 .0 to + 7V 

Power Dissipation 2.5 Watt 



'NOTICE: stresses above those listed under "Absolute Maximum Ratings" 
may cause permanent damage to the device. This is a stress rating only and 
functional operation of the device at these or any other conditions above 
those indicated in the operational sections of this specification is not 
implied. Exposure to absolute maximum rating conditions for extended 
periods may affect device reliability. 



D.C. CHARACTERISTICS 

8088: Ta=0°C to70°C, Vcc = 5V ±10% 



Symbol 


Parameter 


MIn. 


Max. 


Units 


Test Conditions 


V,L 


Input Low Voltage 


-0.5 


+ 0.8 


V 




V|H 


Input High Voltage 


2.0 


Vcc + 0.5 


V 




Vol 


Output Low Voltage 




0.45 


V 


Iql = 2.0 mA 


VOH 


Output High Voltage 


2.4 




V 


loH = 400 mA 


•cc 


Power Supply Current 




340 


mA 




ly 


Input Leakage Current 




±10 


mA 


OV<VIN<Vcc 


Ilo 


Output Leakage Current 




±10 


^.A 


0.45V < VouT < Vcc 


VCL 


Clock Input Low Voltage 


-0.5 


+ 0.6 


V 




VCH 


Clock Input High Voltage 


3.9 


Vcc+10 


V 




C|N 


Capacitance of Input Buffer 
(All input except 
AD0-AD7 RQ/GT) 




15 


pF 


fc = 1 MHz 


Cio 


Capacitance of I/O Buffer 
(AD0-AD7 RQ/GT) 




15 


pF 


fc = 1 MHz 
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A.C. CHARACTERISTICS 

8088: Ta = 0°C to 70°C, Vcc = 5V ± 10% 

8088 MINIMUM COMPLEXITY SYSTEM TIMING REQUIREMENTS 








Symbol 


Parameter 


Min. 


Max. 


Units 


Test Conditions 




TCLCL 


CLK Cycle Period 


200 


500 


ns 




TCLCH 


CLK Low Time 


(VjTCLCL) 


-15 




ns 


TCHCL 


CLK High Time 


( V3 TCLCL) -t 


2 




ns 


TCH1CH2 


CLK Rise Time 




10 


ns 


From 1.0V to 3.5V 


TCL2CL1 


CLK Fall Time 




10 


ns 


From 3.5V to 1.0V 


TDVCL 


Data In Setup Time 


30 




ns 




TCLDX 


Data In Hold Time 


10 




ns 


TR1VCL 


RDY Setup Time into 8284 (See Notes 1, 2) 


35 




ns 


TCLR1X 


RDY Hold Time into 8284 (See Notes 1, 2) 







ns 


TRYHCH 


READY Setup T ime into 8088 


('/3TCLCL)-15 




ns 


TCHRYX 


READY Hold Time into 8088 


30 




ns 


TRYLCL 


READY Inactive to CLK (S?e Note 3) 


-8 




ns 


THVCH 


HOLD Setup Time 


35 




ns 


TINVCH 


INTR. NMI. TEST Setup Time (See Note 2) 


30 




ns 




TIMING RESPONSES 








Symbol 


Parameter 


Min. 


Max. 


Units 


Test Conditions 




TCLAV 


Address Valid Delay 


15 


110 


ns 


CL = 20-100pFfor 
all 8088 Outputs 
In addition to 
internal loads 


TCLAX 


Address Hold Time 


10 




ns 


TCLAZ 


Address Float Delay 


TCLAX 


80 


ns 


TLHLL 


ALE Width 


TCLCH-20 




ns 


TCLLH 


ALE Active Delay 




80 


ns 


TCHLL 


ALE Inactive Delay 




85 


ns 


TLLAX 


Address Hold Time to ALE Inactive 


TCHCL-10 




ns 


TCLDV 


Data Valid Delay 


10 


110 


ns 


TCHDX 


Data Hold Time 


10 




ns 


TWHDX 


Data Hold Time After WR 


TCLCH-30 




ns 


TCVCTV 


Control Active Delay 1 


10 


110 


ns 


TCHCTV 


Control Active Delay 2 


10 


110 


ns 


TCVCTX 


Control Inactive Delay 


10 


110 


ns 


TAZHL 


Address Float to READ Active 







ns 


TCLRL 


RD Active Delay 


10 


165 


ns 


TCLRH 


RD Inactive Delay 


10 


150 


ns 


TRHAV 


RD Inactive to Next Address Active 


TCLCL-45 




ns 


TCLHAV 


HLDA Valid Delay 


10 


160 


ns 


TRLRH 


RD Width 


2TCLCL-75 






ns 1 


TWLWH 


WR Width 


2TCLCL-60 






TAVAL' 


Address Valid to ALE Low 


TCLCH-60 




ns____ 




NOTES: 1. Signal at 8284 shown tor reference only. 

2. Setup requirement for asynchronous signal only to guarantee recognition at next CLK. 

3. Applies only to T2 state (B ns Into T3 state). 
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CLK (8284 Output) 



RDY (8284 Input) 
SEE NOTE 5 



READY (8088 fnput) 



READ CYCLE 
(NOTE 1) 

(wR. n^m < voh) 



Ti 
- TCLCL - 



VCL 



X 



K 



/ 



)C 



\ 



TCHLL— 

-TAVAL — 



t— TCL2CL1 ; 



^TCLCH-» 



Ais-A< (Float during INTA) 



)C 



X 



n 



\ 



(— TCLR1X 



< 



TCHCTV TCLRL 




J- 



\ 



JCZ 



T 



I 

J 



il^S 




c 



Figure 11: 8088 Bus Timing — Minimum Mode System 
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CLK (a2e4 Output) 



WRITE CYCLE 
N0TE1 



INTA CYCLE 

NOTES 1,3 

(RD.WB-Voh) 



SOFTWARE HALT - 
SEN.RO.WR.INTA = VOH 




SOFTWARE HALT 



1. ALL SIGNALS SWITCH BETWEEN Vqh AND Vol UNLESS OTHERWISE 
SPECIFIED. 

2. ROY IS SAMPLED NEAR THE END OF T}, T3, Tw TO DETERMINE IF Tw 
MACHINES STATES ARE TO BE INSERTED. 

3. TWO INTA CYCLES RUN BACK.TO-BACK. THE 80M LOCAL ADDR/DATA 
BUS IS FLOATING DURING BOTH INTA CYCLES. CONTROL SIGNALS 
ARE SHOWN FOR THE SECOND INTA CYCLE. 

4. SIGNALS AT 82M ARE SHOWN FOR REFERENCE ONLY. 

5. ALL TIMING MEASUREMENTS ARE MADE AT 1.$V UNLESS OTHERWISE 
NOTED 



Figure 12. 8088 Bus Timing — Minimum Mode System (cont.) 
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B088 MAX MODE SYSTEM (USING 8288 BUS CONTROLLER) 
riMING REQUIREMENTS 








Symbol 


Parameter 


MIn. 


Max. 


Units 


T«st Condillons 


i 


TCLCL 


CLK Cycle Period 


200 




500 


ns 






TCLCH 


CLK Low Time 


(2/3 TCLCL)- IE 




ns 


- 




TCHCL 


CLK High Time 


(V3TCLCL) + 2 




ns 


TCH1CH2 


CLK Rise Time 




10 


ns 


From 10V to 3 5V 


TCL2CL1 


CLK Fall Time 




10 


ns 


From 3 5V to 1.0V 


TDVCL 


Data In Setup Time 


30 




ns 


- 


TCLDX 


Data In Hold Time 


10 




ns 


TR1VCL 


RDY Setup Time into 8284 (See Notes 1. 2) 


35 




ns 


TCLR1X 


RDY Hold Time into 8284 (See Notes 1, 2) 







ns 


TRYHCH 


READY Setup Time mto 8088 


(%TCLCL)-15 




ns 


TCHRYX 


READY Hold Time into 8088 


30 




ns 


TRYLCL 


READY Inactive to CLK (See Note 4) 


-8 




ns 


TINVCH 


Setup Time for Recognition (INTR, NMI, TEST) (See Note 2) 


30 




ns 


TQVCH 


RQ/gT Setup Time 


30 




ns 


TCHGX 


RQ Hold Time into 8086 


40 




ns 


TIMING RESPONSES 








Symbol 


Parameter 


MIn. 


Max. 


Units 


Test Conditions 




TCLML 


Command Active Delay (See Note 1) 


10 


35 


ns 


Cl= 20-100 pF for 
all 8088 Outputs 
in addition to 
internal loads 


TCLMH 


Command Inactive Delay (See Note 1) 


10 


35 


ns 


TRYHSH 


READY Active to Status Passive (See Note 3) 




110 


ns 


TCHSV 


Status Active Delay 


10 


110 


ns 


TCLSH 


Status Inactive Delay 


10 


130 


ns 


TCl,AV 


Address Valid Delay 


15 


110 


ns 


TCLAX 


Address Hold Time 


10 




ns 


TCLA2 


Address Float Delay 


TCLAX 


80 


ns 


TSVLH 


Status Valid to ALE High (See Note 1) 




15 


ns 


TSVMCH 


Status Valid to MCE High (See Note 1) 




15 


ns 


TCLLH 


CLK Low to ALE Valid (See Note 1) 




15 


ns 


TCLMCH 


CLK Low to IMCE High (See Note 1) 




15 


ns 


TCHLL 


ALE Inactive Delay (See Note 1) 




15 


ns 


TCLMCL 


MCE Inactive Delay (See Note 1) 




15 


ns 


TCLDV 


Data Valid Delay 


15 


110 


ns 


TCHDX 


Data Hold Time 


10 




ns 


TCVNV 


Control Active Delay (See Note 1) 


5 


45 


ns 


TCVNX 


Control Inactive Delay (See Note 1) 


10 


45 


ns 


TA2RL 


Address Float to Read Active 







ns 


TCLRL 


RD Active Delay 


10 


165 


ns 


TCLRH 


RD Inactive Delay 


10 


150 


ns 


TRHAV 


RD Inactive to Next Address Active 


TCLCL-45 




ns 


TCHDTL 


Direction Control Active Delay (See Note 1) 




50 


ns 


TCHDTH 


Direction Control Inactive Delay (See Note 1) 




30 


ns 




TCLGL 


GT Active Delay 






110 


ns 


TCLGH 


GT Inactive Delay 




85 


ns 
ns 


TRLRH 


RD Width 


2TCLCL-75 










NOTES: 1. Signal at 8284 or 8288 shown for reference only. 

2. Setup requirement for asyncfironous signal only to guarantee recognition at next CLK. 

3. Aptilies only to T3 and wait states. 

4. Applies only to T2 state (8 ns into T3 state). 
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Si.Si.So (EXCEPT HALT) 



ALE (8288 OUTPUT) 



WDY (8284 INPUT) 



READY (8068 INPUT) 



READ CYCLE 



B2M OUTPUTS 
SEE NOTES 5.6 



MRbC OR iOHC 



TCH1CH2— 



± 



4 



X 



X 



1 



\ 




Tj 
TCL2CL1 



X 



XA_rA 



X 



mw- 



X 



-^TCLCH — 



X 



,, 1 .A i ]v ' . i \. - ,, , , i , 



TCLAX 
TCLAZ 



/' 



y 



^^ 



}C 



X 



X 



-TDVCL -t— TCLDX 



\ 



■^1 



\ 




Figure 13. 8088 Bus Timing — Maximum Mode System (Using 8288) 
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VCH r 
L— / 



Si. Si. Si (EXCEPT HALT) 

WRITE CYCLE 

AOr-AOo 

OEN 



•288 OUmjTS 
SEE NOTES 54 



AMWC OR AlOWC 



MCE/ 
WDfEFJ 



/V-^^^' 

m--' 




\: 




AO7-AD0. A,j-A, 



X 



INVALID ADDRESS 



\ 



/■ 



1. ALL SIGNALS SWITCH BETWEEN Vo„ AND Vol UNLESS OTHERWISE 
SPECIFIED 

2. ROY IS SAMPLED NEAR THE END OF T,. Tj. Ty, TO DETERMINE IF Tw, 
MACHINES STATES ARE TO BE INSERTED. 

3. CASCADE ADDRESS IS VALID BETWEEN FIRST AND SECOND INTA 
CYCLES 

4. TWO INTA CYCLES RUN BACK-TO BACK. THE SOU LOCAL ADOR/DATA 
BUS IS FLOATING DURING BOTH INTA CYCLES. CONTROL FOR 
POINTER ADDRESS IS SHOWN FOR SECOND INTA CYCLE 

5. SIGNALS AT a2S< OR >2U ARE SHOWN FOR REFERENCE ONLY 

e. THE ISS UANC E OF T HE (2U COMMAND AND CONTROL SIGNALS 
(MHDC. WWTC. AVWC, IOUC, roWC. flOWC. IBTA AND DEN) ' GS THE 
ACTIVE HIGH CU CEN 

7. ALL TIMING MEASUREMENTS ARE MADE AT 1.5V UNLESS OTHERWISE 
NOTED. 

». STATUS INACTIVE IN STATE JUST PRIOR TO T, 
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X 



Figure 15. Asynchronous Signal Recognition 



» — Any CLK Cycle — 



\ 



/ 



Figure 16. Bus Lock Signal Timing (Maximum Mode Only) 



y CLK Cycl« -— 1- - 



TCLGH L -. -—I * — TGVCH 

[, i -TCLCL —A - TCHGX -, — 'tCLGL, 

s —^ N^j PULsei ly-H \ i v^l 

/ Y. COPROCESSOR / Y. 

, A \ ^ / ! V 



Atittg- Aiatts 
ADr-ADo 
m. C06R 



ULSC 3 r- 
iocessor/ 

ELEASE / 



X 



COPROCESSOR 



MH 



Figure 17. Request/Grant Sequence Timing (Maximum Mode Only) 




K 



COPROCESSOn 



X 



Figure 18. Hold/Hold Acknowledge Timing (Minimum Mode Only) 
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ABSOLUTE MAXIMUM RATINGS* 

Temperature Under Bias 0*C to 70*C 

Storage Temperature - 65 'C to + 1 50 'C 

All Output and Supply Voltages - 0.5V to + 7V 

All Input Voltages - 1.0V to + 5.5V 

Power Dissipation 1 Watt 



'NOTICE: Stresses above those listed under "Absolute Maximum Ratings" 
may cause permanent damage to the device. This is a stress rating on!/ and 
functional operattoh of the device at these or any other conditions above 
those indicated in the operational sections of this specification is hot 
implied. Exposure to absolute maximum rating conditions for extended 
periods may affect device reliability. 



D.C. CHARACTERISTICS 

Conditions: Vcc = 5V ± 10%, Ta = 0°C to 70° C 



Symbol 


Parameter 


MIn 


Max 


Units 


Test Conditions 


Vc 


Input Clamp Voltage 




-1 


V 


Ic = -5 mA 


Ice 


Power Supply Current 




160 


mA 




•f 


Forward Input Current 




-0.2 


mA 


Vp = 0.45V 


Ir 


Reverse Input Current 




50 


mA 


Vr = 5.25V 


Vol 


Output Low Voltage 




.45 


V 


Iql = 32 mA 


VOH 


Output High Voltage 


2.4 




V 


'oh = - 5 mA 


•off 


Output Off Current 




±50 


^LA 


VoFF = 0.45 to 5.25V 


V,L 


Input Low Voltage 




0.8 


V 


Vcc = 5.0V See Note 1 


V,H 


Input Higfi Voltage 


2.0 




V 


Vcc = 5.0V See Note i 


C|N 


Input Capacitance 




12 


PF 


f=^MHz 

Vbias = 2.5V, Vcc =5V 

Ta = 25°C 



Notn: 1. Output Loading loi_ = 32 mA. loH=-5mA, Cl = 300pF 



A.C. CHARACTERISTICS 

Conditions: Vcc = 5V ± 10%, Ta = CC to 70° C 

Loading: Outputs — Iql = 32 mA, Iqh = - 5 mA, Cl = 300 pF 



Symbol 


Parameter 


Min 


Max 


Units 


Test Conditions 


TIVOV 


Input to Output Delay 
—Inverting 
—Non-Inverting 




22 

30 


ns 
ns 


(See Note 1) 


TSHOV 


STB to Output Delay 
—Inverting 
—Non-Inverting 




40 
45 


ns 
ns 


TEHOZ 


Output Disable Time 




18 


ns 


TELOV 


Output Enable Time 


10 


30 


ns 


TIVSL 


Input to STB Setup Time 







ns 


TSLIX 


Input to STB Hold Time 


25 




ns 


TSHSL 


STB Higfi Time 


15 




ns 



NOTE: 1. See waveforms and test load circuit on following page. 
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xznx 



-TSLIX--] 



i 



--TIVOV— I 



i 



/ 1 



TEH02 1— TELOV 

V0H-.1V 



A 



> < 

-^ V0Lr.1V 1^ 



NOTE: 1.8283 ONLY — OUTPUT MAY BE MOMENTARILY INVALID FOLLOWING THE HIGH GOING STB TRANSITION. 
2. ALL TIMING MEASUREMENTS ARE MADE AT 1.5V UNLESS OTHERWISE NOTED, 



OUT O <• 



300 pF 



3-STATE TO Vql 



OUT O 11 



^ 300 pF 



3-STATE TO Vqh 



;^ 300 pF 



Figure 4. Output Test Load Circuits 
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OUTPUT DELAY VS. CAPACITANCE 
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Figure 5. Output Delay vs. Capacitance 
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ABSOLUTE MAXIMUM RATINGS* 

Temperature Under Bias 0°Cto70*C 

Storage Temperature - 65*C to + 150'C 

All Output and Supply Voltages - 0.5V to + 7V 

All Input Voltages - l.OV to + 5.5V 

Power Dissipation 1 Watt 



'NO TICE: Stresses above those listed under "Absolute Maximum Ratings" 
may cause permanent damage to the device. This is a stress rating only and 
functional operation of the device at these or any other conditions above 
those indicated in the operational sections of this specification is not 
implied. Exposure to absolute maximum rating conditions for extended 
periods may affect device reliability. 



D.C. CHARACTERISTICS 



Conditions: T 


A = 0'C to 70'C; Vcc=5V± 10% 










Symbol 


Parameter 


MIn 


Max 


Units 


Test Conditions 


If 


Forward Input Current 




-0.5 


mA 


Vf = 0.45V 


•r 


Reverse Input Current 




50 


mA 


Vr= 5.25V 


Vc 


Input Forward Clamp Voltage 




-1.0 


V 


lc=-5mA 


Ice 


Power Supply Current 




140 


mA 




V|L 


Input LOW Voltage 




0.8 


V 


Vcc = 5.0V 


V|H 


Input HIGH Voltage 


2.0 




V 


Vcc = 5.0V 


V.HR 


Reset Input HIGH Voltage 


2.6 




V 


Vcc=5.0V 


Vol 


Output LOW Voltage 




0.45 


V 


5 mA 


VOH 


Output HIGH Voltage CLK 
Other Outputs 


4 
2.4 




V 
V 


-1 mA 
-1 mA 


VlHR-V,Lp 


RES Input Hysteresis 


0.25 




V 


Vcc=5.0V 



A.C. CHARACTERISTICS 

Conditions: Ta = 0''C to /CC; Vcc = 5V± 10% 
TIMING REQUIREMENTS 



Symbol 


Paramatar 


MIn 


Max 


Unlti 


Test Condltlona 


TEHEL 


External Frequency High Time 


13 




ns 


90% - 90% V||4 


TELEH 


External Frequency Low Time 


13 




ns 


10% - 10% V|N 


TELEL 


EFI Period 


TEHEL -(• TELEH-,- <) 




ns 


(Note 1) 




XTAL Frequency 


12 


25 


MH2 




TR1VCL 


RDY1, RDY2 Set-Up to CLK 


35 




ns 




TCLR1X 


R0Y1, RDY2 Hold to CLK 







ns 




TA1VR1V 


AEni, AEN2 Set-Up to RDY1, R0Y2 


15 




ns 




TCLA1X 


AEN1, AEN2 Hold to CLK 







ns 




TYHEH 


CSYNC Setup to EFI 


20 




ns 




TEHYL 


CSYNC Hold to EFI 


20 




ns 




TYHYL 


CSYNC Width 


2 TELEL 




ns 




TI1HCL 


RI§ Set-up to CLK 


65 




ns 


(Note 2) 


TCLI1H 


Res Hold to CLK 


20 




ns 


(Note 2) 
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TIMING RESPONSES 



Symbol 


Parim«t*r 


MIn 


Max 


Units 


Test Conditions 


TCLCL 


CLK Cycle Period 


125 




ns 




TCHCL 


CLK High Time 


(V3TCLCL) + 2.0 




ns 


Fig 3 & Fig. 4 


TCLCH 


CLK Low Time 


('/3 TCLCL) -15.0 




ns 


Fig. 3 & Fig. 4 


TCH1CH2 
TCL2CL1 


CLK Rise or Fall Time 




10 


ns 


iavto3 5V 


TPHPL 


POLK High Time 


TCLCL- 20 




ns 




TPLPH 


PCLK Low Time 


TCLCL -20 




ns 




TRYLCL 


Ready Inactive to CLK (See Note 4) 


-8 




ns 


Fig. 5 & Fig 6 


TRYHCH 


Ready Active to CLK (See Note 3) 


(»/^TCLCL)-15.0 




ns 


Fig. 5 a Fig. 6 


TCLIL 


CLK to Reset Delay 


40 




ns 




TCLPH 


CLK to PCLK High Delay 




22 


ns 




TCLPL 


CLK to PCLK Low Delay 




22 


ns 




TOLCH 


OSC to CLK High Delay 


-5 


12 


na 




TOLCL 


OSC to CLK Low Delay 


2 


20 


na 





NetoK 1 i > EFI riaa (S ns max) + EFI fall (6 na max). 

2. Set up and hold only necessary to guarantee recognition at next clock. 
3; Applies only to T3 and TW states. 
4. Applies only to T2 states. 




TCLPH - 
-^\L. TPLPM — 






^ 



^ — U. TCLAi: 



^ 



x: 



^ 



t 



ALL TIMINO MEASUDEMCNTS ARE MADC AT IS VOLTS. UNLESS OTHEHWISE NOTED 



I- TPMPl +-1 



— TCLII M — H- TM HCL — 



A.C. TEST CIRCUITS 
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ABSOLUTE MAXIMUM RATINGS* 

Temperature UnderBlas 0*Cto70*C 

Storage Temperature -65°C to + 150°C 

All Output and Supply Voltages - 0.5V to + 7V 

All Input Voltages -1.0V to +5.5V 

Power Dissipation 1 Watt 



'NOTICE: Stresses above those listed under "Absolute Maximum Ratings" 
may cause permanent damage to the device. This is a stress rating only and 
functional operation of the device at these or any other conditions above 
those indicated in the operational sections ot this specification is not 
implied Exposure to absolute maximum rating conditions for extended 
periods may affect device reliability 



D.C. CHARACTERISTICS FOR 8286/8287 

Conditions: Vcc = 5V ±10% Ta = 0°C to 70° C 



Symbol 


Parameter 


Min 


Max 


Units 


Test Conditions 


Vc 


Input Clamp Voltage 




-1 


V 


lc=-5mA 


"cc 


Power Supply Current— 8287 
-8286 




130 
160 


mA 
mA 




If 


Forward Input Current 




-0.2 


mA 


Vf = 0.45V 


Ir 


Reverse Input Current 




50 


mA 


Vr = 5.25V 


Vol 


Output Low Voltage —B Outputs 
— A Outputs 




.45 
.45 


V 
V 


lOL = 32 mA 
lot = 16 mA 


VOH 


Output High Voltage —B Outputs 
— A Outputs 


2.4 
2.4 




V 
V 


'oh =-5 mA 
loH=-1 mA 


Iqff 
Ioff 


Output Off Current 
Output Off Current 




If 
Ifl 




VoFF = 0.45V 
VoFF = 5.25V 


V,L 


Input Low Voltage —A Side 
— B Side 




0.8 
0.9 


V 
V 


Vcc = 5.0V, See Note 1 
Vcc = 5.0V, See Note 1 


V|H 


Input High Voltage 


2.0 




V 


Vcc= 5.0V, See Note 1 


C|N 


Input Capacitance 




12 


pF 


F=1 MHz 

Vb,as = 2.5V, Vcc =5V 

Ta = 25-C 



Noir 1. B Outputs — Iol = 32 mA, Ioh = -5 mA, Cl = 300 pF A Outputs — loL = 16 mA, loH = -1 mA, Cl = 100 pF 



A.C. CHARACTERISTICS FOR 8286/8287 

Conditions: Vcc = 5V ±10%, Ta = 0°C to 70° C 
Loading: B Outputs — Iql = 32 mA, Iqh = -5 mA, Cl = 300 pF 
A Outputs — Iql = 16 mA, Iqh = -1 mA, Cl = 100 pF 



Symbol 


Parameter 


Min 


Max 


Units 


Test Conditions 


TIVOV 


Input to Output Delay 
Inverting 
Non-Inverting 




22 
30 


ns 

ns 


(See Note 1) 


TEHTV 


Transmit/Receive Hold Time 


TEHOZ 




ns 


TTVEL 


Transmit/Receive Setup 


30 




ns 


TEHOZ 


Output Disable Time 




18 


ns 


TELOV 


Output Enable Time 


10 


30 


ns 



Nolt: 1 See waveforms and test load circuit on following page. 
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8286/8287 



I 



X 



i 1 



TEHOZ |»- TELOV-* 
^j VOH - .IV 

___>r Vol + .IV 



< 



t 



NOTE: 1. ALL TIMING MEASUREMENTS ARE MADE AT 1.5V UNLESS OTHERWISE NOTED. 



8286/8287 TIMING 
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400 (00 
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1000 




200 


40O 600 800 
pF LOAD 
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Figure 4. Output Delay vs. Capacitance 



3-STATE TO Vql 



B OUTPUT 



^jISOOpF 
3-STATE TO VoH 

B OUTPUT 



1.SV 

I 



;j;ioopF 



3STATE TO Vql 



A OUTPUT 



;^ioopF 

3-STATE TO Vqh 

A OUTPUT 



B OUTPUT 



;^ioopF 



A OUTPUT 



Figure 5. Test Load Circuits 
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ABSOLUTE MAXIMUM RATINGS* 

remperature Under Bias O'C to 70 'C 

Storage Temperature -65*C to + 150'C 

All Output and Supply Voltages - 0.5V to + 7V 

All Input Voltages - 1 .C y to + 5.5V 

Power Dissipation 1.5 Watt 



'NOTICE: Stresses above ttiose listed under "Absolute Maximum Ratings" 
may cause permanent damage to the device. This is a stress rating only and 
functional operation of the device at these or any other conditions above 
those indicated in the operational sections of thiis specification is not 
implied. Exposure to absolute maximum rating conditions for extended 
periods may affect device reliability. 



D.C. CHARACTERISTICS 

Conditions: Vcc=5V ±10%, Ta = 0''C to 70°C 



Symbol 


Parameter 


Min 


Max 


Unit 


Test Conditions 


vc 


Input Clamp Voltage 




-1 


V 


IC = - 5 mA 


Ice 


Power Supply Current 




230 


mA 




If 


Forward Input Current 




-07 


mA 


Vf = 0.45V 


IR 


Reverse Input Current 




50 


^A 


Vr=Vcc 


Vol 


Output Low Voltage— Command Outputs 
Control Outputs 




05 
05 


V 
V 


'0L = '52 mA 
l0i.= 16 mA 


VOH 


Output High Voltage- Command Outputs 
Control Outputs 


24 
2.4 




V 
V 


l0H= -5 mA 
l0H= -1 mA 


V|L 


Input Low Voltage 




0.8 


V 




V|H 


Input High Voltage 


20, 




V 




'off 


Output Off Current 




100 


mA 


VoFF = 0'4to5 25V 



A.C. CHARACTERISTICS 

Conditions: Vcc=5V ±10%, TA = 0°Cto70°C 
TIMING REQUIREMENTS 



Symbol 


Parameter 


Min 


Max 


Unit 


Loading 


TCLCL 


CLK Cycle Period 


125 




ns 




TCLCH 


CLK Low Time 


66 




ns 




TCHCL 
TSVCH 


CLK High Time 


40 




ns 




Status Active Setup Time 


65 




ns 




TCHSV 


Status Active Hold Time 


10 
55 




ns 




TSHCL 


Status Inactive Setup Time 


ns 




TCLSH 


Status Inactive Hold Time 


10 




ns 





TIMING RESPONSES 



Symbol 


Parameter 


Min 


Max 


Unit 


Loading 


TCVNV 


Control Active Delay 


5 


45 


ns 




TCVNX 


Control Inactive Delay 


10 


45 


ns 


TCLLH.TCLI^CH 


ALE MCE Active Delay (from CLK) 




15 


ns 


TSVLH.TSVMCH 


ALE MCE Active Delay (from Status) 




15 


ns 


TCHLL 


ALE Inactive Delay 




15 


ns 


lORC 

MV»fTC 

lOWC 


Iql = 32 mA 

. loH = - 5 mA 

CL = 300pF 


TCLt^L 


Command Active Delay 


10 


35 


ns 


TCLI^H 


Command Inactive Delay 


10 


35 


ns 


TCHDTL 


Direction Control Active Delay 




50 


ns 


INTA 


TCHDTH 


Direction Control Inactive Delay 




30 


ns 


AMWC 


TAELCH 


Command Enable Time 




40 


ns 


' 'OL= ^^ "** 
Other { loH= -1 "i* 
1 Cl = 80pF 


TAEHCZ 


Command Disable Time 




40 


ns 


TAELCV 


Enable Delay Time 


115 


200 


ns 


TAEVNV 


aEn to DEN 




20 


ns 


TCEVNV 


CEN to DEN, PDEN 




20 


ns 


TCELRH 


CEN to Command 




TCLML 


ns 




1 
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S2. 5i, So 
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— JTS 
— TCLSH 



DT/fi (READ) 
(INTA) 
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J 
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X 



X 



v 



© 



\ 
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/ 



/ 



/ 



\ 



7® 



I — ) r— TSVMCH 



j\ 



/ 



1. ADOACSSff>ATA BUS IS SHOWN ONLY F0« HEFCRENCE PURPOSES 

2. UACMNO EDGE OF ALE AND MCE IS DETEnHINEO BY TM£ FALLING EDOE OF CLK OR STATUS OOiNQ ACTIVE. WHtCHEVCfl OCCURS LAST 
1 AU nHINQ MEASUREMENTS ARE MADE AT 1 5V UNLESS S 



8288 Timing Diagram 
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X 



I 



tUf. 

TCEVNV 



DEN, PDEN Qualification Timing 



_ TAELCV - 



^ 



jr 




/' 



J 



ITAEHCZ 

|- ►] 0.5V 



\: 



\ 



TCEIRH- 
NOTE: CEN MUST BE I OW OR VALID PRIOR TO T2 TO PREVENT THE COMMAND FROM BEING GENERATED. 



8288 Address Enable (AEN) Timing (3-State Enable/Disable) 



3-$TATE TO HIGH 



3.STATE TO LOW 



Test Load Circuits - 3 State Command Output Test Load 
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Chapter 6 
THE ZILOG Z8000 SERIES 

The Z8000 series of microprocessors represent Zilog's first 16-bit products. The Z8000 is the second of the new 
16-bit microprocessor generation. Intel's 8086, described in Chapter 5, was the first product to appear. Motorola's 
MC68000 will likely be the next 

Two Z8000 series microprocessors have been announced. The Z8002 is a 40-pin package device capable of ad- 
dressing up to 65,536 bytes of external memory. The Z8001 is a 48-pin package .device capable of addressing up to 
eight million bytes of external memory, organized as segments of 65,536 bytes. A third device, the Z8010 Segmenta- 
tion and Memory Manager, is a companion to the Z8001. The Z8010 allows memory segments to be dynamically allo- 
cated under program control anywhere within the eight million bytes of addressable memory. 

The Z8000 series microprocessors are upward compatible at the source program level with the 8080A and the 
Z80. 

The following is a comparison of interesting Z8000 and 8086 innovations: 

1) Z8000 microprocessors do not pipeline instruction object codes, but under some circumstances they do overlap 
the next instruction's fetch with the prior instruction's execute. In contrast, the 8086 has a 6-byte object code 
pipeline, which, with associated instruction fetch overlap timing, effectively eliminates instruction fetch times. 

2) The Z8001 and the Z8002 can be visualized as supporting complex and simple microcomputer configurations, 
respectively. In contrast, a single 8086 can operate either in complex mode, comparable to the Z8001 , or in simple 
mode, comparable to the Z8002. 

3) Both the Z8001 and the Z8002 have built-in logic to handle bus access prioritiesjn multi-CPU configurations. The 
8086 has equivalent logic. 

4) In multi-CPU configurations, each Z8000 series CPU can have its own local memory, while simultaneously sharing 
common memory. The common memory may be shared by all CPUs or by selected CPUs. In this respect, the 8086 
and the Z8000 series are comparable. 

5) The Z8001 can address up to eight million bytes of external memory. With the help of the Z8010 Segmentation 
and Memory Management Device, this large external memory can be accessed as up to 128 relocatable segments, 
where each segment can have up to 65,536 bytes of external memory. The 8086 offers similar relocatable seg- 
ments without relying on an additional memory management device; however, the 8086 can directly address only 
one million bytes of external memory and can only manipulate four segments at a time. 

6) Both Z8000 series microprocessors can be operated in separate "System" and "Normal" modes. Certain privileged 
instructions, including all I/O instructions, can be executed in System mode only. System and Normal modes have 
separate Stacks, with separate Stack Pointers, Thus, in program-intensive applications, systems software, executed 
in System mode, can be separated from application programs, executed in Normal mode. The 8086 offers no 
equivalent logic. 

7) The Z8000 has sixteen 16-bit registers that can alternatively be accessed as 8-bit or 32-bit registers. Fifteen of the 
16-bit registers can function as index registers. The 8086, in contrast, has four 16-bit registers, plus three separate 
16-bit index registers. 

The prime source for the Z8000 series is: 

ZILOG, INC. 

10460 Bubb Road 

Cupertino. C A 95014 
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Second sources include: 

ADVANCED MICRO DEVICES 
901 Thonnpson Place 
Sunnyvale. CA 94086 

SGS-ATES COMPONENTI ELETTRONICI SPA 

20019 Castelletto di Settimo 

Agrate (Milano) 

Italy 

The Z8000 series microprocessors are manufactured using N-channel silicon gate MOS technology. The Z8001 is 
packaged as a 48-pin DIP. The Z8002 is packaged as a 40-pin DIP. Both devices require a single -1-5 V power supply. All 
signals are TTL-level compatible. 

The Z8000 requires an external clock with up to 4 MHz frequency. Instructions execute in a minimum of three clock 
periods. The maximum number of clock periods is approximately 20; however, a number of instructions require more 
time to execute a variety of complex operations. 
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THE Z8001 AND Z8002 CPU'S 



Because these two versions of the Z8000 CPU are so similar, we will describe them together. Functions imple- 
mented by Z8000 series microprocessor chips are, in terms of our general illustration, equivalent to those of the 
8086, as illustrated in Figure 5-1. 

Z8001 AND Z8002 PROGRAMMABLE REGISTERS 

Programmable registers for the Z8001 and Z8002 microprocessors are illustrated in Figures 6-1 and 6-2, 
respectively. 

Registers RO through R15 can be used as general purpose accumulators. Registers R1 through RIB can, in addi- 
tion, function as index registers. Register RO is the only general purpose register which cannot function as an index 
register. 

Both the Z8001 and the Z8002 can be operated in System mode or Normal mode. A 

status flag setting determines the mode of operation. System mode will normally be used by 
operating system software; Normal mode will be used by application programs. A number of 
instructions, including all I/O instructions, are privileged, and consequently can be executed in 
System mode only. System and Normal modes have separate Stack Pointers. These are 
shown in Figures 6-1 and 6-2 by S and N suffixes, which represent "System" and "Normal" 
modes, respectively. 

For the Z8002, the single 16-bit register R15 serves as the Stack Pointer. 

For the Z8001, two 1 6-bit registers are needed to implement a Stack Pointer, since memory addresses may be up to 23 
bits wide. Registers R14 and R15 are used. 

Instructions that access 16-bit registers do not make any special allowance for R15 and/or R14 functioning as Stack 
Pointers. Thus, the Steele Pointer can be accessed as a general purpose register/accumulator, or it can be used as 
the Index register for indexed memory addressing. The fact that there are separate System and Normal mode Stack 
Pointers is inconsequential when these registers are being accessed as accumulators or index registers. Depending on 
the currently selected mode, one or the other Stack Pointer will be accessible. This may be illustrated as follows: 

Normal System 

Mode Mode 



Z8000 

SYSTEM AND 
NORMAL 
MODES 



Z8000 STACK 
POINTERS 



R11 

R12 

R13 

R14(orR14N) 

R15N 



R11 

R12 

R13 

RU (orR14S) 

R15S 



Whenever two 16-bit registers provide a memory address for the Z8001, register bits 
are utilized as follows: 



Z8001 32-BIT 

ADDRESS 

REPRESENTATION 



15 


14 13 12 11 10 9 8 


7 


6 


5 


4 


3 


2 


1 


- 


[l 


Segment No. 























ol 




L 


Offset 










J 



< Bit No. 

Register RN holds the 

7-blt segment number in 

bits 8-14. Other register bits are 0. 

Register RN+1 holds the 
1 6-bit offset, or 
address within the 
segment identified in 
Register RN. 
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15 


14 


13 


12 


11 


10 


9 


8 


7 


6 


5 


4 


3 


2 


1 


' 


L 






























J 



■Bit No. (for all registers) 



RE 



Segment Offset 



Segment Offset 



Segment No. 



Segment Offset 



Rate 



Accumulators and 
Index Registers 






Segment No. 





























Segment No. 



























RO - Accumulator 

R, ^ 

R2 

R3 

R4 

R5 

R6 

R7 > 

R8 

R9 

RIO 

R11 

R12 

R13 

R14S 

RUN 

System and Normal Stack Pointers, 
ofcc i Accumulators and Index Registers 



I 



R15N 









Segment No. 


























Upper Offset 



























Row 



Flags and Control Word 



Program Counter 



New Program Status Area Pointer 



Refresh Counter 



Figure 6-1. Z8001 Microprocessor Programmable Registers 
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15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 -^ Bit No. (for all registers) 

I RO - Accumulator 



\f& 



n 



1 


1 


1 


1 


1 


1 


1 


^^:l 



\ 





1 


1 


1 


1 1 




^— ^--l 


1 1 






1 






■-•■,.--..;■■■■::- 



R1 
R2 
R3 
R4 
R5 
R6 
R7 
R8 
R9 



Jrio 



Accumulators and 
Index Registers 



R11 
R12 
R13 
R14 

R''5S I System and Normal Stack Pointers, 
R15N 1 ^<^<^"'Tiulators and Index Registers 

Flags and Control Word 
Program Counter 



Uf^MT Ptprtw^ 



$, 



3 



b I New Program Status Area Pointer 



Rate 



Row 



Refresh Counter 



Figure 6-2. Z8002 Microprocessor Programmable Registers 
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The segment number and offset translate into a 23-bit memory address as follows: 




Thus, the Z8001 Stack Pointer is shown in Figure 6-1 with bits 8 through 14 of Register R14 pro- 
viding the segment number, while the whole of Register R15 provides the segment offset. The 
Z8002 Stack Pointer, shown in Figure 6-2, is a simple 16-bit address register. 

The Program Counter is a simple 16-bit register for the Z8002, but fortheZ8001 two 16-bit words 
are used, with the 23-bit address divided into a segment number and an offset, as illustrated 
above. 



Z8000 
STACK 
POINTER 



Z8000 

PROGRAM 

COUNTER 



The Z8000 addresses memory as bytes; however 16-bit words must originate on even byte address bound- 
aries. That is why the Z8001 uses two 16-bit words to generate extended memory addresses, even though only 23 bits 
of address are required. 23-bit addresses could be implemented in three bytes, rather than in two 16-bit words; 
however, this would complicate pushing and popping memory addresses. Were the addresses implemented as three 
bytes, all Stack operations would require three byte pushes or three byte pops. By making all addresses occupy two 16- 
bit words. Stack operations are reduced to two word pushes or two word pops which require no more time than three 
byte pushes or pops. 

The Flags and Control Word provides the Z8001 and the Z8002 with Status and Control bits. Z8000 

Bits are interpreted as follows: STATUS 



15 14 13 12 11 10 9 8 



SEG S/N 



n ii 



ii a 



p/o 



DA 




Bit No. 

Reserved word, Z8001 only 

Flags and Control Word (FCW) 



-Auxiliary Carry 
-Decinnal Adjust 
■ Parity or Overflow 
-Sign 
-Zero 
• Carry 

-Non-vectored interrupt enable/disable 
■Vectored Interrupt enable/disable 
-System/normal mode select 
■Segmentation mode select (Z8001 only) 
Always for Z8002 
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The Parity, Overflow, Sign, Zero, and Carry statuses are absolutely standard. 

Parity and Overflow share a status bit. 

The Parity status is modified by logical instructions which test the parity of byte data. This status is set to 1 for even 
parity; it is cleared for odd parity. 

The Overflow status is equal to the Exclusive OR of carries out of the high-order and penultimate bits following 
arithmetic and logical operations. 

The Sign status is set to the value of the high-order result bit following arithmetic operations. 

The Zero status is set to 1 when the result of an operation is 0; it is reset to otherwise. 

The Carry status reports carries out of the high-order bit following arithmetic operations. This status is also used by 
most shift and rotate instructions. 

Most microprocessor instructions routinely modify status bits, whether or not such modifications are relevant to the 
operation performed. Z8000 status logic generally follows the PDP-1 1 minicomputer, but the Z8000 has a few 
anomalies. You should therefore consult Table 6-3, which summarizes the Z8000 instruction set, in order to deter- 
mine how a particular status is affected by the execution of any specific instruction. 

The Auxiliary Carry and Decimal Adjust status flags differ somewhat from normal use. These flags are modified by 
byte arithmetic instructions in order to make binary coded decimal arithmetic possible. You cannot set or reset these 
two Status flags using any of the status bit control instructions, and reading the value of these flags provides little 
useful information. The assembly language programmer should ignore these two flags. 

NVIE and VIE are used to enable and disable non-vectored interrupts and vectored interrupts, respectively. You 

enable interrupts by setting the appropriate status bit to 1, and you disable interrupts by resetting the appropriate 
status bit to 0. 

The S/N status flag is used to switch between System and Normal modes. When this bit is 1, Z8000 
microprocessors operate in System mode. When this bit is 0, ZBOOO microprocessors operate in Normal mode. Recall 
that System and Normal modes have their own separate Stack Pointers; also, certain privileged instructions can only be 
executed in System mode. 

The SEG status is used by the Z8001 microprocessor only. When this bit is set to 1, the Z8001 operates in Seg- 
mented mode; when this bit is set to 0, the Z8001 operates in Nonsegmented mode. 



In Segmented mode, all Z8001 addresses are computed 23 bits wide, using two 16-bit memory Z8001 

words as previously illustrated. Z8001 Nonsegmented, Normal mode is directly equivalent to SEGMENTED 

Z8002 Normal mode operations. Z8001 Nonsegmented System mode is not exactly equivalent to MODE 

Z8002 System mode; differences occur in interrupt acknowledge stack handling, as explained 
later in this chapter. Thus Z8002 Normal mode programs can be executed within any single segment of Z8001 memo- 
ry- 

The Z8001 carries an unused word as a companion to the Flag and Control Word, since all Z8001 automatic Stack 
operations push and pop data in word pairs. Status in the Flag and Control Word must also be pushed and popped as a 
32-bit unit — hence the unused companion word. 
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The New Program Status Area Pointer is used by interrupt logic. It consists of one or two 16-bit 
words, as illustrated in Figures 6-1 and 6-2. 

Following any interrupt acknowledge, a vector address is created using the New Program Status 
Area Pointer and a 9- or 10-bit displacement provided by interrupt acknowledge logic, as follows: 



Z8000 NEW 
PROGRAM 
STATUS AREA 
POINTER 



Z8001 



15 14 13 12 11 10 9 8 7 6 



-Bit No. 



Segment No. 



15 14 13 12 1 


10 9 


8 7 6 5 4 3 2 1 





1 Upper Offset 


|o|o o|o|o|o|o 


>J 


' ? 


♦ 


♦ ♦ 


♦ 


1 Displacement 


♦ 




♦ 



SN6 



SNO A15 



All A10 



Interrupt Vector 
Address 



■Bit No. 



Upper Offset 



t 
A15 



IXi 



3 



Displacement 



♦ T 

A10 A9 



T 

AO 



Interrupt Vector 
Address 



AO 



Although the Z8002 uses just one byte of its New Program Status Area Pointer, 16 bits are provided, since all Z8002 
automatic Stack operations push and pop 16-bit words. Likewise, the Z8001 New Program Status Area Pointer uses 
two 16-bit words, where a single 16-bit word would suffice, to accommodate automatic Stack handling logic which 
pushes and pops data in 32-bit increments. 

The Refresh Counter will be described later, along with memory refresh. 
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Z8000 REGISTER DESIGNATIONS 

Z8000 series microprocessor instructions access 8-bit, 1 6-bit, or 32-bit registers, as illustrated in Figure 6-3. 

Register designations used by Zilog assembly language mnemonics are shown in this figure. 

Byte instructions access sixteen 8-bit registers, illustrated in Figure 6-3 by RHO througli RL7. 



Z8000 BYTE 
REGISTERS 



Z8000 16-BIT 
REGISTERS 



Z8000 32-BIT 
REGISTERS 



Word instructions access the sixteen 16-bit registers RO through R15. 

Long word instructions access general purpose registers in pairs. Eight 32-bit registers are 
therefore available, shown in Figure 6-3 as RRO through RR14. 

Most Z8000 series instructions that access memory or registers have a word version and a byte 
version. A limited number of instructions have a long word version. 

lyAultiplication and division instructions sometimes use 64-bit registers, shown in Figure 6-3 as RQO through 
RQ12. 

Z8001 AND Z8002 MEMORY ADDRESSING MODES 

IMost Z8001 memory addressing modes have two forms: one for Nonsegmented mode, the other for Seg- 
mented mode. 

When operating in Nonsegmented mode, all Z8001 memory reference instructions compute nonsegmented memory 
addresses: the offset address is modified, but the segment number is not altered. 

When operating in Segmented mode, Z8001 memory reference instructions compute segmented memory addresses, 
provided the instruction also has a segmented memory addressing option. But there are some memory reference in- 
structions that have no segmented option; these instructions compute nonsegmented memory addresses, even for a 
Z8001 operating in Segmented mode. 

A segmented memory reference instruction computes new values for the segment number and offset address. 

The Z8002 Program Counter is a single, 16-bit register, equivalent to the Z8001 Program Counter Offset register. 
Z8002 memory reference instructions therefore compute nonsegmented memory addresses only. 

In the discussion which follows, we will illustrate ZBOOO memory addressing options for Segmented and Nonseg- 
mented modes. 



nented mode the be 

two 16-bit words: 


se address always specifies the segment. The base add 

er 
13 12 11 10 9 8 7 6 5 4 3 2 1 


ress may 


Z8001 
BASE 
ADDRESS 


Word or Register Numb 
15 14 


•^ Bit No. 




n| 


Segment No. 


























1 Long form 






\ segmented mode 
/ base address 


n+ 1 1 


1 6-Bit Offset 


1 (not in instruction) 


Instruction word 

15 14 


13 12 11 10 9 8 7 6 5 4 3 2 1 


-^ Bit No. 


p[7 


Segment No. 


























1 Long form 






1 segmented mode 
/ base address 


P + l| 


16-Bit Offset 


1 (in instruction) 



or it may occupy a single 16-bit instruction word: 

15 14 13 12 11 10 9 8 



3 2 1 



Segment No. 



8-bit Offset 



Bit No. 

Short form segmented 
mode base address 
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Z8002 

15 



8 7 



RHO 



RH1 



RH2 



RH3 



RLO 



-Bit No 

1\ for all 
RO I registers \ RO 

RRO 



Z8001 

► 15 



8 7 



RHO 


RLO 



RL1 



RL2 



RL3 



RR2 



RH1 



RL1 



1 RH2 


RL2 1 



RQO 



1 ■ RH3 ■ 


RL3 1 



RH4 



RH5 



RH6 



RH7 



RL4 



RL5 



RL6 



RR4 



RR6 



RL7 



R4 

R5 

R6 

'r7 



RH4 



RL4 



1 RH& 


RL5 1 



RQ4 



RH6 


RL6 1 



fW7 


RL7 1 




1 




RQ8 



SSP 



NSP 




RR14 
R15S| |R15S 
R15N| |r15N 



SSPSEG 



NSPSEG 



SSPOFF 



NSPOFF 



RQ12 



FCW/FLAGS 



PC 



PSAP 



]\ 



Flags and 
Control Word 



]l 



Program Counter 



]( 



New Program 
Status Area 



FLAGS 



PSAPSEG 



PSAPOFF 



FCW 



PC 



PSAP 



Figure 6-3. Various Register Designations for the Z8001 and Z8002 Microprocessors 
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The index or displacement portion of a memotY address never specifies the memory segment. The index is always a 
single 16-bit value for any Z8000 microprocessor, operating in any mode. The displacement may be an 8-bit, 12-bit, or 
16-bit value; but once again, it is the same for all Z8000 microprocessors, and all modes of operation. 

Thus, in Segmented mode, there is a clear difference between a base address and an index or displacement. In Non- 
segmented mode, there being no segment number, there is no difference between a base address and an index. 

Most Z8000 series memory reference instructions access data memory using implied, direct, or indexed memo- 
ry addressing. 

Z8002 implied memory addressing may be illustrated as follows: 

1 6-bit 



Registers 






Memory 










xxxx-1 




^xxxx 




xxxx+1 













Z8000 
IIVIPLIED 
IVIEiyflORY 
ADDRESSING 



Bytes 



X represents any hexadecimal digit 

The Z8001 uses only nonsegmented implied memory reference instructions to access data memory. The Z8001 does 
not use either short or long segmented implied memory addressing to access data memory. Z8001 implied memory ad- 
dressing may therefore be illustrated as follows: 



16-bit 
Registers 



Memory 





RN-1 

RN <^ Instruction specifies 

RN+1 memory address is 
register RN. Memory 
byte ss xxxx is j 


ss xxxx-1 

^ss xxxx 

|ss xxxx+1 

1 ss xxxx+2 

ss xxxx +3 








xxxx 




f 




\ 




\ 




\ / 





s and X represent any hexadecimal digits 



Bytes 

Segment number ss 
is current contents 
of Program Counter 
Segment register. 
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SomeZSOOl program memory reference instructions (such as the subroutine call) use long segmented implied memory 
addressing, which may be illustrated as follows: 



1 6-Bit 
Registers 



ss 00 



RRN-1 



RRN 



Instruction specifies 
memory address in 
Register RN. Memory 
byte xxxx In segment 
ss is accessed. 




Program 
Memory 











ssxxxx-1 




l^ssxxxx 




ss XXXX+ 1 













Bytes 



s and X represent any hexadecimal digits. 
RRN is a 32-bit register designation. 

We will now examine direct memory addressing. 

For the Z8002, direct memory addressing may be illustrated as follows: 

Memory 



PPPP 

The direct address xxxx is PPPP+1 
provided by the instruction PPPP+2 
object code pppp+3 




Z8002 
DIRECT 
MEMORY 
ADDRESSING 



Instruction code 
Direct Address 





) 1 


xxxx-1 




► xxxx 




xxxx+1 




xxxx+2 













x and p represent any hexadecimal digits 

Note that the direct address xxxx, being a 1 6-bit value, must start at a memory byte with an even address. This require- 
ment is illustrated above by the address pppp+2. 

Furthermore, the high-order byte of a 16-bit memory word is at the lower address, preceding the low-order byte: 



1 6-bit data from memory 





Program 
Memory 


High-order 
byte 

hh 

t 


Low-order 
byte 


pppp 




II ie 


pppp+1 




a 


pppp+2 


hh 








PPPP+3 


II 








pppp+4 
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A Z8001 direct memory address may be nonsegmented, short segmented, or long segmented. Nonsegmented 
Z8001 direct memory address logic is as illustrated above for a Z8002 direct memory address, except that the most re- 
cently computed segmented number is output from the Program Counter Segment register via the seven Z8001 seg- 
ment number lines. 
Long segmented Z8001 direct memory addressing may be illustrated as follows: 



The direct address 
xxxx, in segment 
ss, is provided by 
the Instruction 
object code 





Memory 


tt pppp 




ttpppp+1 




ttpppp+2 


ss 


tt pppp+3 


00 


tt pppp+4 


XX 


ttpppp+5 


XX 


tt pppp +6 


/ 




■^ 




1 t 


ss xxxx-1 




^ ss xxxx 




ssxxxx+1 









Z8001 LONG 
SEGMENTED 
DIRECT MEMORY 
ADDRESSING 



' Instruction code 



Long segmented 
direct address 



s and t are any hexadecimal digits that specify a segment number in the range 00 through 7Fi 5. 
p and X are any hexadecimal digits that specify a memory address within a segment. 



We can illustrate a short segmented Z8001 direct memory addessing as follow/s: 



Segment Number 



Memory 



\ 



Offset 



V 



OOxx. 

The direct address 
OOxx, in segment 
ss, is provided by 
the instruction 
object code 







tt pppp 




ttpppp+1 




tt pppp+2 


ss 


tt pppp+3 


XX 


tt pppp+4 


j 


tt pppp +5 


J 




V 






ss OOxx-1 




^ss OOxx 




ssOOxx+1 









Z8002 SHORT 
SEGMENTED 
DIRECT MEMORY 
ADDRESSING 



> Instruction code 

) Short segmented 
I direct address 



s and t are any hexadecimal digits that specify a segment number in the range 00 through 7F 1 5. 
p and X are any hexadecimal digits that specify an offset, or memory address within the segment. 



6-13 



Z8001 and Z8002 indexed memory addressing adds the contents of an index register to a direct address. 16-bit 
registers R1 through R15 can function as index registers. Register RO cannot function as an index register. The direct 
address provides the base to which an index is added. 

Z8002 indexed addressing may be illustrated as follows: 



1 6-blt 
Registers 







RN-1 




RN 


yyyy 


RN+1 


I 




\ 



Memory 



Z8002 

INDEXED 

ADDRESSING 








pppp 




pppp+1 




pppp+2 


XX 


pppp+3 


XX 




y 






zzzz-1 




^ zzzz 




zzzz+1 









> Instruction code 

(^Direct 
I Address 



p, X, y and z represent any hexadecimal digits. The selected memory address zzzz is the sum of the 
direct address xxxx, which is provided by the Instruction object code, and the index yyyy. 
The instruction code specifies Register RN as the Index register. 

The illustration applies also to nonsegmented Z8001 indexed addressing, but for the Z8001 a segment number (ss) 
would precede the computed address zzzz. Since no segment is computed by the Z8001 in Nonsegmented mode, ss 
would be the current contents of the Program Counter Segment register. 



Here is an illustration of Z8001 short segmented indexed addressing: 



16-blt 
Registers 



Memory 




Z8001 SHORT 
SEGMENTED 
INDEXED 
ADDRESSING 



tt pppp 






tt pppp+1 




) 


tt pppp+2 


ss 


» 


tt pppp+3 


XX 


/ 


tt pppp+4 


/ 




—J 


y 










ss zzzz-1 






^ ss zzzz 






ss zzzz+1 













' Instruction code 

Short segmented 
direct address 



Segment digits are not 
affected by this addition. 

Any carry out of high-order 
digit addition will be lost. 

The effective memory address ss zzzz is not the simple sum of ss OOxx and yyyy. The segment number ss is output 
directly on the segment number pins, bypassing the address addition. OOxx and yyyy are added to create zzzz, the 
offset, which is output on the Address Bus. In the event that adding OOxx to yyyy generates a carry out of the high- 
order bit, this carry is lost. Thus the offset addition wraps around from FFFF-ig to 0000-] 5. without incrementing the 
segment number. 
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Long segmented Z8001 indexed addressing uses a four-byte direct address, witli a 16- 
bit offset, as follows: 

Memory 



00 



Z8001 LONG 
SEGMENTED 
INDEXED 
ADDRESSING 



The computed offset zzzz becomes the sum of xxxx and yyyy. 

Note that long segmented indexed addressing offers the same addressing range as short segmented indexed 
addressing; the index, on its own, can address the entire offset space of 65,536 bytes. Therefore, the one-byte short 
segmented base address offset is no handicap. Suppose, for example, you use indexed addressing to access a data ta- 
ble in the middle of a segment. Using long segmented indexed addressing, the base of the data table might be provided 
by the direct address offset, while the Index register provides the displacement into the selected table: 



Memory 
Table 



Origin xxxx from- 
base address 



Displacement Into 
table from Index register 



But you could just as easily have the index originate at the base of the segment: 

Memory 

Table 

Start of Segment 



Base address 
offset = 00 



0000' 



Start of Table- 



Displacement Into 
table, from segment 
origin. In Index register 



A few Z8001 and Z8002 instructions access data memory using base relative addressing, 
wherein the contents of an Index register are added to a base address, which is also held in 
CPU registers. Therefore, Z8000 base relative addressing might also be called "implied, in- 
dexed" addressing. 



Z8000 BASE 

RELATIVE 

ADDRESSING 



Z8000 IMPLIED 

INDEXED 

ADDRESSING 
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Z8002 base relative addressing may be illustrated as follows: 

16-bit 
Registers 



Base address 



Memory 



RM-1 




RM 


xxxx 


RM+1 


' 




I 
1 


RN-1 


/- 


RN 


yyyv 


RN+1 





Index 



X, y and z represent any hexadecimal digits 











zzzz-1 




► zzzz 




zzzz+1 














"— V— ^ 



Byte 



The instruction object code must specify the register number from which the base address and the index are tal<en. In 
Nonsegmented mode there is no difference between a base address and an index; each is a single 16-bit value. The 
effective memory address zzzz is simply the sum of any two 16-bit registers' contents. 

The illustration above applies also to nonsegmented Z8001 base relative addressing. However, for the Z8001 the 
memory segment ss, currently in the Program Counter Segment register, is output via the seven Z8001 segment num- 
ber lines. 

Consider next Z8001 segmented base relative addressing. The base address specifies the 
segment, thus the base address and the index differ. Short segmented base relative addressing 
may be illustrated as follows: 

1 6-bit 
Registers Memory 



Z8001 SHORT 
SEGMENTED 
BASE RELATIVE 
ADDRESSING 




Segment number 
Offset 



X, Y and z represent any hexadecimal digits specifying offsets, or addresses within memory segment ss. 
ss can have any value in the range 00 through 7Fi 5. 

The index is added to the base address using the same mechanism described earlier for short segmented indexed ad- 
dressing. The discussion of addressing range given for short segmented indexed addressing applies also to short seg- 
mented base relative addressing. 
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Long segmented base relative addressing may be illustrated as follows: 
1 6-bit 
Registers 



RRM-1 




Byte 



Segment number - 

Offset - 

X, y and z represent any hexadecimal digits specifying an offset address within memory segment ss. 
RRM designates a 32-bit register, while RN designates a 1 6-bit register. 
These registers are specified by the instruction object code. 





Memory 










sszzzz-1 




ss zzzz 




sszzzz+1 













Z8001 LONG 
SEGMENTED 
BASE RELATIVE 
ADDRESSING 



Some program memory reference instructions use program relative addressing. A displace- 
ment provided by the instruction object code is added, as a signed binary number, to the 
contents of the Program Counter. For the Z8002 this may be illustrated as follows: 

Program 
Memory 



Z8002 
PROGRAM 
RELATIVE 
ADDRESSING 



C 





xxxx+4 - dddd/2 ► 

XXXX 
XXXX+ 1 

xxxx+2 
XXXX+3 
xxxx+4 

^ ^^ 

xxxx+4+dddd/2 ^ 




















1 

1 








> op-code 






Program relative 


dd 


) signed binary 


addressing range 


dd 


I displacement 








XXXX+4 + dddd - 


1 

1 





























In the illustration above, dddd is divided by 2 to show the addressing range of a program relative address; this is 
because dddd is a signed binary number. Therefore, half of the possible values will increase the address in the Program 
Counter (xxxx-l-4); the other half will decrease this address. 

Depending on the instruction, dddd may be an 8, 12, or 16-bit signed binary value. This displacement is added to the 
contents of the Program Counter after the Program Counter has been incremented to address the first byte of the next 
sequential instruction. This is illustrated above as location xxxx-l-4. 

Some program relative instructions (such as Jump Relative) have the displacement included in the op-code word, sav- 
ing memory space and execution time for short displacements. In these instructions the first byte of the next sequential 
instruction would be xxxx-l-2, instead of xxxx-l-4 as illustrated above. 
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Z8001 PROGRAM 

RELATIVE 

ADDRESSING 



Z8000 INDIRECT 

MEMORY 

ADDRESSING 



Z8000 AUTO- 
INCREMENT 
AND DECREMENT 



Z8001 program relative addressing, in Segmented or Nonsegmented mode, follows the il- 
lustration above; however, the Program Counter also specifies the memory segment. The dis- 
placement is added to the Z8001 Program Counter Offset register. The Z8001 Program 
Counter Segment register is not changed. Thus the displacement for a program relative memo- 
ry address cannot cross a segment boundary. 

A few Z8000 jump instructions use indirect memory addressing. That is to say, the con- 
tents of the addressed memory location are loaded into the Program Counter. Very few 
microprocessors provide indirect addressing. See Volume 1, Chapter 6 for a detailed descrip- 
tion of this addressing mode. 

The Z8000 instruction set includes a number of memory reference instructions with 
auto-increment and auto-decrement. An implied memory address held in a 16-bit register is 
incremented or decremented following an instruction's execution, thus leaving the address 
pointing to the next sequential memory location in a table or string. 

The Z8000 Steele decrements the Stack Pointer before a push and increments the Stack 
Pointer following a pop. In other words, the beginning of the Stack has the highest memory 
address, and the current top of Stack has the lowest memory address. 

Z8001 AND Z8002 PINS AND SIGNALS 

Signals and pin assignments for the two Z8000 series microprocessors are illustrated in Figure 6-4. 

AD0-AD15 is a multiplexed 16-bit Data/Address Bus. AS is an address strobe which is pulsed low while an ad- 
dress is being output. DS is a data strobe which is pulsed low while data is being output or input 

ST0-ST3 are four machine cycle status signals whose output levels further identify bus activity, as summarized in 
Table 6-1. 

Table 6-1. Z8000 Machine Cycle Status Definitions 



Z8000 
STACK 





ST3 


■STO 




Machine Cycle 










3 


2 


1 



















Internal operation 













Memory refresh 








1 





I/O reference 








1 




Special I/O reference 





1 








Segmentation trap acknowledge 





1 







Non-maskable interrupt acknowledge 





1 


1 





Non-vectored interrupt acknowledge 





1 


1 




Vectored interrupt acknowledge 













Data memory access 












Stack memory access 







1 





Reserved 







1 




Reserved 




1 








Subsequent instruction fetch 




1 







First instruction fetch 




1 


1 





Reserved 




1 


1 




Reserved 
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Pin Name 


Description 


Type 


AD0-AD15 


Data/Address Bus 


Bidirectional, Tristate 


SNO - SN6* 


Segment Number 


Output, Tristate 


B/W 


Byte/Word Select 


Output, Tristate 


R/W 


Read/Write Select 


Output, Tristate 


N/S 


Normal/System Mode Select 


Output, Tristate 


STO - ST3 


Machine Cycle Status 


Output, Tristate 


WAIT 


Wait State Request 


Input 


CLOCK 


System Clock 


Input 


AS 


Address Strobe 


Output, Tristate 


DS 


Data Strobe 


Output, Tristate 


MREQ 


Memory Request 


Output, Tristate 


VI 


Vectored Interrupt Request 


Input 


NVI 


Non-vectored Interrupt Request 


Input 


NMI 


Non-maskable Interrupt Request 


Input 


RESET 


System Reset 


Input 


SECT* 


Segmentation Trap 


Input 


BUSRQ 


Bus Request 


Input 


BUSAK 


Bus Acknowledge 


Output 


Ml 


Multi-micro Input 


Input 


MO 


Multi-micro Output 


Output 


STOP 


Single-Step Stop 


Input 


DECOUPLE" 


Negative Bias Generator 


Output 


Vcc. GND 


Power, Ground 




• Z8001 


nly "Not presently cor 


nected 



Figure 6-4. Z8001 and Z8002 Signals and Pin Assignments 
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MREQ is output lo w whe n memory is being addressed. MREQ high, when a valid address is output, therefore 
selects an I/O port. MREQ indicates codes 7, 8, 9. C or F output via ST0-ST3; but ST0-ST3 also provide additional 
variations of memory and I/O access machine cycles. 



DS and MREQ can generate a rudimentary memory select signal, as follows: 




MREQ 



AO A15 



If I/O is being mapped into memory space, you can ignore MREQ. 

B/W differentiates between byte and word memory accesses. Z8000 memory is organized and addressed _as bytes; 
however, the 16-bit Data/Address Bus allows 8-bit or 16-bit data accesses within a single machine cycle. B/W is out- 
put high for an 8-bit access: it is output low for a 16-bit access. 

In order to simplify the memory interface logic needed to enable byte and word accesses, the Z8000 

Z8000 always reads data from even-addressed bytes on the high-order eight Data Bus lines; ly/IEMORY 

it reads data from odd-addressed bytes on the low-order eight Data Bus lines. This may be il- INTERFACE 

lustrated as follows: LOGIC 



AD15 




During a one-byte Read instruction, a Z8000 microprocessor will take data from the high-order eight Data Bus lines if 
the memory address is even; it takes data from the low-order eight Data Bus lines if the memory address is odd. The 
data is transferred by the CPU to the selected 8-bit register. 

In response to a 16-bit read, a Z8000 microprocessor takes data from the 16-bit bus and loads it into the selected 
register. The high-order byte of the 16-bit word will come from the even-addressed memory byte. The low-order byte of 
the 16-bit word will come from the odd-addressed memory byte. This may be illustrated as follows: 



8 7 



Bit No. 




Memory 





xxxx-2 




xxxx-1 


pp 


xxxx 


qq 


XXXX+ 1 




xxxx+2 
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When a Z8000 microprocessor executes a one-byte Write instruction, the same byte of data is output on the eight 
high-order and low-order Data Bus lines. This may be illustrated as follows: 



1 6-bit Registers 

-I- 




ADO-* 



Z) 



AD15-* 



iri 



pp 



pp 



During execution of a 16-bit write instruction, a Z8000 microprocessor will output the selected 16 bits of data in the 
usual way: across AD0-AD15, the 16-bit Data Bus. 

There are a number of ways in which memory interface logic can be designed to comply with Z8000 Data Bus 
protocols, but the simplest methodis to divide memory into two halves, with even-addressed bytes in one-half and 
odd-addressed bytes in the other half. The two halves of memory will in fact have parallel addresses taken from AD1- 
AD15, with ADO and B/W combining to generate appropriate select logic. This may be illustrated as follows: 





Byte Memory 




sn ,^'— I /^ if 1 






r— ^ SF 




Byte Memory 




witn 
odd addresses 

A0A14 DO D7 


^^^vtr^iv-i 








r^>^- 


with 
even addresses 

AO A14 DO D7 


V,_J 






1— -^ 


i 


1 i 


' y 


1 


' 


i.i 


' u. 






i 


, 


^ 


•-, 












^ 






I 


*- , 


, *■, 










^ 


■ 






*- " 


^ 






? 


• 
• 


• 






, 


r 


• 






.1 


? 


• 


» 




„ : 



B/W 

AS 

A/DO 

A/D1 

A/D7 
A/D8 

A/D15 

The illustration above shows two blocks of memory with parallel addresses decoded from the same 15 address 
lines: AD1 -AD1 5. The block of mennory labelled "odd addresses" has a Data Bus connection to AD0-AD7. The block of 
memory labelled "even addresses" has a Data Bus connection to AD8-AD15. 

The block of memory with odd addresses is selected when SO is low; this occurs when B/W and ADO are both low, or 
when they are both high. Thus, odd-addressed memory responds to byte accesses with odd addresses, or to word ac- 
cesses with even addresses. 

The block of memory with even addresses is enabled when SE is low. This occurs for any even address access. 

The illustrated memory select logic ensures that no memory is selected by a word access with an odd address. To 
Z8000 microprocessors this is an illegal condition. 

The Z8000 microprocessors also access 32-bit memory "long words." Such accesses occur serially, as two 16-bit 
words, therefore no special memory interface logic is required. 

N/S and various ST0-ST3 combinations can be used to separate memory functionally. 

N/S is output low when a Z8000 microprocessor is operating in System mode; it is output high in Normal mode. 

Thus, N/S can be used to condition memory select logic so that separate System and Normal mode memory can exist in 
parallel address spaces. Similarly, if ST0-ST3 is input to a 4-to-16 decoder, statuses 2 and 3 can enable separate I/O 
spaces, statuses 8 and 9 can select separate Data and Stack memories, whMe statuses C and D select program memory. 
Some or all of these status combinations can be used, with or without N/S, to implement a variety of special memory 
spaces. If all external memory e_xists in a single address space, which is how most microcomputer memory is con- 
figured, then you can ignore N/S. 
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For the Z8001 only, memory is segmented, and the currently selected segment is identified by the 7-bit output 
SN0-SN6. In the absence of a Z801 Memory Management Device, SN0-SN6 is directly decoded to select appropriate 
memory segments. In the presence of a Z8010 Memory Management Device, however, memory select logic can ignore 
the concept of segmentation, instead deriving addresses from a 24-bit Address Bus which is output by the Z8010 
Memory Management Device. 

During a memory or I/O access machine cycle, R/W is output high for a read and low for a write. 



Slow memory or I/O devices can input WAIT low in order to extend a machine cycle, thereby gaining more access 
response time. WAIT timing is described later in this chapter. 

CLOCK is the single 5 V clock signal required by all Z8000 microprocessors. 

There are three interrupt request inputs: 

NMI is the highest priority, non-maskable interrupt request. 

VI is the vectored interrupt request. 

NVI is the lowest priority, non-vectored interrupt request. 

NMI is active on high-to-low transitions. VI and NVI are active-low signals. 

SECT is a segmentation trap interrupt request which is transmitted by the Z8010 Memory Management Device to 
the Z8001 in response to an illegal segmentation condition. 

The response of Z8000 series microprocessors to interrupt requests is described in detail later in this chapter. 



When RESET is input low, Z8000 microprocessors are reinitialized. Reset logic is described later, following descrip- 
tions of logic which is affected by a Reset. 



The BUSRQ and BUSAK signals are used by di rect me mory access logic; they may also be used by CPU priority arbitra- 
tion logic in multi-CPU configurations. When BUS RQ is in put low, a Z8000 series microprocessor will respond by 
floating its three-state bus lines and outputting BUSAK low at the end of the next machine cycle. Timing for these 
two signals is given later in this chapter. 

Ml and MO are used by CPU priority arbjtration logic in multi-CPU configurations. Under program control, Z8000 
series microprocessors can test the level of Ml and control the level of MO, thus enabling a primitive level of handshak- 
ing between CPUs. 

STOP allows Z8000 programs to be exec uted one instruction at a time, thus enabling implementation of typical 
computer single-stepping debug logic. The STOP signal is described later, together with Z8000 refresh logic. 

DECOUPLE is not currently connected. This signal will be used by later versions of the Z8000 microprocessor; it will 
function as an output from an internal negative bias generator. 
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Z8001 AND Z8002 TIMING AND INSTRUCTION EXECUTION 



Z8000 MEMORY 
READ MACHINE 
CYCLE 



Z8000 series microprocessors execute instructions in straightforward sequences of machine cycles. Z8000 
machine cycles may vary in length from 3 to 1 clock periods. 

Z8000 MEMORY REFERENCE MACHINE CYCLES 

Normal memory reference machine cycles have three clock periods. Timing for memory read and memory write 
machine cycles is illustrated in Figures 6-5 and 6-6, respectively. 

Beginning witli the memory read machine cycle, note that the levels output at ST0-ST3 
represent the only difference between a memory read or an instruction fetch machine 
cycle. A valid 16-bit address is output via AD0-AD15 during the first clock period. AS is 
pulsed low at this time; external logic should use the trailing low-to-high transition of the AS 
pulse as its valid address strobe. For a Z8002 this 16-bit address is the total address informa- 
tion output by the microprocessor. But for the Z8001 , this 1 6-bit address is an offset within the 
segment specified by SN0-SN7. The segment is specified during the last clock period of 
the previous machine cycle so that the Z8010 Memory Management Device will have one 
clock period within which to compute an effective address. Timing may be illustrated as follows: 



CLOCK 



Z8000 

INSTRUCTION 
FETCH MACHINE 
CYCLE 



SN0-SN6 




External logic must have stable data on the Data/Address Bus during T3. 

During a memory write machine cycle, as illustrated in Figure 6-6, the address is output dur- 
ing the first clock period and is valid on the trailing low-to-high transition of the AS pulse, as 
described for a memory read. Data output appears at ADO-AD 15 immediately after the ad- 
dress. Data output is stable during the low DS pulse. 

External logic can extend any memory reference machi ne cycle by insertin g Wait state 
clock periods between T2 and T3. The CPU samples WAIT in the middle of T2; if WAIT is low, 
then a Wait state clock period is inserted. Wait state clock periods continue to be inserted until 
WAIT is sampled high in the middle of a Wait clock period. Timing may be illustrated as follows: 



Z8000 MEMORY 
WRITE MACHINE 
CYCLE 



Z8000 WAIT 
STATE 




CLOCK 



WAIT 



<k=^ 



Signal levels and conditions that existed at the end of T2 are maintained for the duration of Wait clock periods. 
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CLOCK r^~" 

-A 



ADO-AD 15 



AS 



MREQ 



DS 



R/W 



} 



I 



-T1- 



^ 



4 



Address Out 





Data In 



ST0-ST3 



Address 
Valid 



Figure 6-5. A Z8000 Memory Read or Instruction Fetch Machine Cycle 
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ADO-AD 15 



AS 



MREQ 



DS 



R/W 



ST0-ST3 



-T2- 



-T3- 



CLOCK C5s~" 



^2^ r 



Address / Out 



Data Out 



{ 




Figure 6-6. A Z8000 Memory Write Machine Cycle 



Z8000 INPUT/OUTPUT MACHINE CYCLES 

Input and output machine cycles each have a minimum of four clock periods, as illustrated in Figures 6-7 and 
6-8. 

Input and output machine cycles are very similar to memory read and write machine cycles. These are the significant 
differences: 

1) One Wait clock period is always inserte d between T2 and T3 for an I/O machine cycle. Additional Wait clock 
periods can be inserted using the WAIT control input 



2) MREQ is high during an I/O machine cycle since memory is not being referenced. 

3) The status output at ST0-ST3 is 2 or 3, depending on the nature of the I/O instruction. 

A 16-bit address is output during all I/O machine cycles. Therefore, up to 65,536 I/O ports may be addressed. 
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h 



CLOCK (S 



ADO-AD 15 



AS 



MREQ 



DS 



R/W 



ST0-ST3 



Address 7 Out 



r?^. 




T2 H-« TW- 



J \ r 



Data In 



J ^ 



\_ 



Figure 6-7. A Z8000 I/O Port Input Machine Cycle 
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CLOCK X 

-5 



ADO-AD 15 



AS 



MREQ 



DS 



R/W 



ST0-ST3 



Address ^ Out 




TW- 



-+ 



-T3 



J \_^ 



J \_ 



Data Out 



A_ 



Figure 6-8. A Z8000 I/O Port Output Machine Cycle 



CLOCK 



ADO-AD 15 



AS 



ST0-ST3 



-T1- 



-T2- 



-T3- 



5 




Undefined 



J \__/ \^_J 

~) 



Figure 6-9 A ZBOOO Three-Clock-Period Internal Operation Machine Cycle 

Z8000 INTERNAL OPERATION MACHINE CYCLES 

Internal operation machine cycles may have from 3 to 8 clock periods. During the first clock period an un defined 
ad[dress is output, together with an address strobe; ST0-ST3 are output low to identify the internal operation. MREQ, 
DS, and R/W are all high. Timing for a three-clock-period internal operation machine cycle is illustrated in Figure 
6-9. 
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Z8000 INSTRUCTION FETCH OVERLAP 

The Z8000 has a limited instruction fetch overlap ability. If any instruction concludes with one or more internal 
operation machine cycles, then the last internal operation machine cycle can overlap the next instruction's first instruc- 
tion fetch machine cycle. This may be illustrated as follows: 



n-2 



n-1 



-Machine Cycle No. 



Instruction x 



EX 



INT OP 



INT OP 



-Machine Cycle No. 



Instruction x + 1 



EX 



EX 



INT OP - Internal operation machine cycle 

EX - Any machine cycle 

IF - Instruction fetch machine cycle 

Note that the next instruction's instruction fetch machine cycle cannot overlap a memory load instruction since there 
are no trailing internal operation cycles. Also, the last machine cycle of a jump instruction cannot be overlapped since 
the location of the following instruction has not been determined. 

The Z8000 will only overlap a single instruction fetch machine cycle. For example, suppose an instruction concludes 
with four internal operation machine cycles, and the next instruction has two words of object code; the first object 
code word will be fetched during the previous instruction's last internal operation machine cycle, even though there 
are sufficient trailing internal operation machine cycles to fetch both words of the next instruction's object code. This 
may be illustrated as follows: 



n-4 



n-3 



n-2 



n-1 



-Machine Cycle No. 



Instruction x EX INT OP INT OP INT OP INT OP 



-Machine Cycle No. 



Instruction x + 1 



DE 



EX 



The instruction fetch overlap is constant for a given instruction and addressing mode and is accounted for in comput- 
ing the number of clock cycles per instruction. The number of clock cycles is counted from the start of the instruction 
fetch to the start of the next instruction fetch so that the number of clock cycles in an instruction sequence can be 
computed by simply adding the number of clock cycles given for each instruction without worrying about which in- 
structions overlap and which don't 

Z8000 DYNAMIC MEMORY REFRESH 

Z8000 microprocessors have built-in dynamic memory refresh logic. This logic is based on a 
Refresh Counter that can be accessed by special assembly language instructions. The 
Refresh Counter is a 16-bit register which may be illustrated as follows: 



Z8000 

REFRESH 

COUNTER 



13 12 




Bit No. 



Refresh Counter 



Row Identifier 
Rate constant 
Enable 

Refresh logic is enabled by setting bit 1 5 of the Refresh Counter to 1 ■ The refresh rate is determined by the six rate con- 
stant bits. The value in these six bits is decremented on every fourth CLOCK pulse. The rate constant initial value is 
saved and restored when the rate constant decrements to 0. At this time a refresh machine cycle is enabled. 

Thus, using a standard 4 MHz clock, the value loaded into the rate constant bits of the refresh counter allows any inter- 
val ranging between 1 and 64 microseconds to separate memory refresh machine cycles: 

Rate = 4 x CLOCK x (RATE CONSTANT); RATE CONSTANT ^0 
Rate = 4 X CLOCK x 64; RATE CONSTANT = 
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-4- T2 



-T3- 



CLOCK 
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MREQ 



ST0-ST3 




J — V 




J — V 



Refresh =1 



'Address Output = Row from Refresh Counter 
Signals not illustrated preserve values at end of prior machine cycle. 



Figure 6-10. A Z8000 Memory Refresh Machine Cycle 

When the rate constant bits of the Refresh Counter decrement to and trigger a refresh machine cycle, this 
machine cycle will in fact occur at the next available refresh access point in the normal sequence of instruction 
execution machine cycles. These are the available access points: 

1) Following the first instruction fetch machine cycle of any instruction's execution. 

2) In between repeated sequences of machine cycles for instructions with long execution times. These include MULT, 
MULTL DIV, DIVL HALT, MREQ, all shift instructions, and all block move instructions. 

3) During a Stop condition. This is a special case which is described below. 

Memory refresh machine cycle timing is illustrated in Figure 6-10. The refresh address which is output is taken from 
the nine row bits of the Refresh Counter. The Refresh Counter row bits are then incremented by 2. Thus 256 rows may 
be addressed. 

THE Z8000 STOP AND SINGLE-STEPPING LOGIC 

The STOP input signal can be used to suspend an instruction's execution. This logic is frequently used to imple- 
ment single-stepping, whereby a program can be executed one instruction at a time, while being debugged. 

The STOP signal, when input low, puts a Z8000 microprocessor into a Stop condition. The Stop condition begins 
with an instruction f etch m achine cycle, and continues with dynamic memory refresh machine cycles. The Stop 
condition lasts until STOP is input high again. This may be illustrated as follows: 



EX 



EX 



IF 



MR MR 
1} 



MR 



MR 



MR 



EX 



EX 



STOP 



EX - Instruction execute machine cycle. 
IF - Instruction fetch machine cycle. 
MR - Memory refresh machine cycle. 
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The signal is sampled in the middle of the last clock period during the last machine cycle of every instruction's execu- 
tion. This may be illustrated as follows: 



CLOCK 



•T1 



■T2- 



_j — \_y — L_y 




Sample STOP 



•T1- 



I \ f 



Within the Stop condition, the STOP signal is sampled in the middle of the last clock period of every refresh machine 
cycle. 

The initial instruction fetch machine cycle which begins the Stop condition fetches the next sequential instruction. 
This instruction is also executed if it happens to be a short instruction that executes within the one instruction fetch 
machine cycle. But if the fetched instruction requires additional execution machine cycles, then these are suspended 
until the end of the Stop condition. 

Therefore, the Stop condition may separate two instructions, or it may split a single instruction. 



If a one-machine-cycle instruction follows STOP being detected low, then this entire instruction is executed at the 
beginning of the Stop condition, and a new instruction is executed at the end of the Stop condition. This may be illus- 
trated as follows: 

ih 



EX 



MR 



MR MR 
ii 



MR 



MR 



MR 



EX 



STOP 



V 



Instruction n 
executed 



Instruction n + 1 
executed 



In this case, the STOP signal must be brought low before the end of the next machine cycle in order to stop after the 
next instruction fetch for single-stepping. This may be illustrated as follows: 



EX 



MR 



MR 



STOP 



-?^ 



MR 



MR 



MR 



-??- 



J — V 



MR 



MR 



Instruction n 
executed 



Instruction n + 1 
executed 



If, on the other hand, a multi-machine cycle instruction is to be executed after STOP is detected low, then the first in- 
struction fetch machine cycle occurs at the beginning of the Stop condition, but remaining machine cycles for the in- 
struction occur at the end of the Stop condition. This may be illustrated as follows: 



e? 

EX IF MR MR MR MR EX 
U 



EX 



STOP 



"e^ 



r 



Instruction n 
executed 



Instruction n 
executed 



Figure 6-11 summarizes Z8000 Stop condition timing. 
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<^ 



Refresh row address 



Figure 6-11. Z8000 Stop Condition Tinning 

While STOP is being input low, refresh logic bypasses the refresh rate constant. The rate constant continues to 
decrement every fourth clock cycle; however, continuous refresh machine cycles are executed, with the nine row bits 
of the Refresh Counter being incremented by 2 following each refresh machine cycle. 



While STOP is input low, refresh machine cycles are executed, as described above, even if refresh logic has been dis- 
abled. 

THE Z8000 HOLD STATE 



The BUSRQ input and BUSAK output provide Z8000 microprocessors with Hold state lo gic. External logic that 
wishes to acquir e bus c ontrol inputs BUSRQ low to the CPU. The CPU samples BUSRQ at the beginnin g of any 
machine cycle, if BUSRQ is low, then at the conclusion of the current m achine cycle, the CPU outputs BUSAK 
low and floats all three-state signals. This condition lasts until BUSRQ is input high again; three clock periods 
later, suspended instruction execution resumes with the machine cycle which would have been executed, had the 
bus not been floated. Timing is illustrated In Figure 6-12. 

Note that the Ml and MO signals are not comparable to BUSRQ and BUSAK. Ml and MO provide program con- 
trolled inter-CPU handshaking; alternatively, they can be looked upon as undefined status input and control output sig- 
nals. 

THE Z8000 HALT STATE 

Following execution of the Halt instruction, a Z8000 microprocessor will enter a Halt state, during which an 
endless sequence of internal operation machine cycles will be executed. If memory refresh logic has been 
enabled, then memory refresh machine cycles will be interspersed among the internal operation machine cycles. The 
time interval between memory refresh machine cycles will be determined by normal Refresh Counter logic. This is in 
sharp contrast to the Stop condition, during which an endless sequence of refresh machine cycles are output, bypass- 
ing Refresh Counter logic. 

No special signal or status is output by a Z8000 microprocessor to identify the Halt state. A Halt state is ended by 
an interrupt, a segmentation trap, or a Reset. These signals are acknowledged as they would be during any internal 
operation machine cycle. This logic is described next 
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Figure 6-12. Z8000 Hold State 

THE Z8000 INTERRUPT ACKNOWLEDGE SEQUENCE 

A non-maskable internipt is requested by a high-to-low transition of NMI. VI, NVI, and SECT, on the other hand, 
are level-sensi tive signals; low levels input at these sign als req uest vectored interrupts (for VI), non-vectored 
interrupts (for NVI), or a segmentation trap interrupt (for SEQT). 

The Z8000 microprocessors have three software traps. They are: 

1. System Call. This interrupt is initiated by tiie execution of a System Call instruction. (See Ta- 
ble 21-2.) 

2. Illegal Instruction. This trap is initiated by an attempt to execute an undefined instruction object code. 

3. Privileged Instruction. Certain instructions are available for execution in System mode only. An attempt to execute 
one of these instructions in Normal mode will cause a Privileged Instruction trap. 

Z8000 CPU logic checl<s for interrupt cond ition s at the beginning of T3, in the la st machine cycle of every instruction's 
execution. A prior high-to-low transition of NMI or a low level at VI, NVI, or SEGT initiates the interrupt acknowledge se- 
quence. In addition, internal traps can generate interrupts. In the event that two or more interrupting conditions exist 
simultaneously, priorities are arbitrated as follows: 

Internal trap (highest) 
Non-maskable interrupt 
Segmentation trap 
Vectored interrupt 
Non-vectored interrupt (lowest) 

The interrupt acknowledge sequence, as illustrated in Figure 6-13, begins with an aborted instruction fetch 
machine cycle. During this machine cycle the next instruction's object code is fetched in the usual way, but this object 
Code is discarded, and the Program Counter is not incremented. The CPU operating mode is automatically switched 
from Normal to System. 
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Last machine cycle Instruction fetch 



Interrupt acknowledge 



Status 
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Figure 6-13. Z8000 Interrupt Acknowledge Sequence 

Following the aborted instruction fetch, there follows an interrupt acknowledge machine cycle which h as five 
Wait states automatically inserted between T2 and T3. External logic can insert additional Wait states, using the WAIT 
input as previously described. During the T3 clock period of the interrupt acknowledge machine cycle, external 
logic must place an "identifier" on the Data Bus. The way in which this identifier is used will vary, depending on the 
nature of the interrupt being acknowledged. The identifier is used by Z8000 interrupt acknowledge logic, in con- 
junction with the New Program Status Area Table, illustrated in Figure 6-14. As shown in Figure 6-14, this table 
can reside anywhere in memory, providing it originates at the beginning of a 256-byte page. The New Program Status 
Area Pointer addresses the origin of the New Program Status Area. 

Each identifiable interrupt has its own data stored in the new program status area. For a nonsegmented Z8002, 
two 16-bit words are stored as follows: 



New Flag and Control 
Word Contents 



New Program Counter 
Contents 



For a segmented Z8001, four 16-bit words are stored as follows: 



Reserved Word 
(always zero) 



New Flag and Control 
Word Contents 



New Program Counter 
Segment Number 



New Program Counter 
Offset 



We described these registers earlier, for the Z8001 and the Z8002, when examining Z8000 programmable registers. 
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Figure 6-14. Z8000 New Program Status Area 
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The segmentation trap, internal software traps, non-maskable interrupt, and non-vectored interrupt have dedicated 
locations in the New Program Status Area. For these interrupts, the identifier which is fetched during the acknowledge 
cycle can be used in any way. Typically, it will identify the source or nature of the interrupt. For a non-maskable inter- 
rupt, a non-vectored interrupt, or segmentation trap, or an internal software trap, all 16 bits of the identifier are avail- 
able. 

For vectored interrupts, the low-order byte of the identifier must provide the offset of the New Program Status Area ad- 
dress for the interrupting device's status area entry. This may be illustrated as follows: 



New Program Status Area Pointer 



Identifier 



XX 00 



FCW from xxl C or pp38 

PC from xxOO + (ss»2 + 7E) or ppOO + (ss«4 + 3C) 



We can summarize identifier interpretations as follows: 

Identifier 

Segmentation trap: iiii 

System Call: wwii 

Illegal Instruction: wwww 

Privileged Instruction: wwww 

Non-Maskable Interrupt: iiii 

Non-Vectored Interrupt: iiii 

Vectored Interrupt: iill 

The summary given above lists the identifier contents as a sequence of four hexadecimal digits. Letters are used as 
follows: 

1) i represents any programmer defined identifier information. 

2) I represents the offset for the memory address in the New Program Status Area where the new Program Counter 
contents are stored. 

3) w represents the first word (or byte) of the Instruction object code for the instruction which causes a software tap. 

Following the interrupt acknowledge machine cycle, data is pushed onto the System Stack, and is loaded into registers, 
in the following sequence: 



Z8002 

Push PC 
Push FCW 
Push Identifier 
Load FCW 
Load PC 



Z8001 

Push PC offset 
Push PC segment 
Push FCW 
Push identifier 
Load FCW 
Load PC segment 
Load PC offset 



A Return-from-lnterrupt instruction discards the word at the top of the System Stack — assuming this to be the iden- 
tifier — then pops the top of the System Stack, restoring the saved Program Counter, and the Flag and Control Word 
contents. The mode is determined by the saved FCW, thus restoring conditions to those that existed before the inter- 
rupt acknowledge. 
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THE Z8000 RESET 

You reset a Z8000 microprocessor by holding the RESET input iow for at least five clock periods. This causes sig- 
nals to be adjusted as follows: 

1) AD0-AD1 5 are floated 

2) 

3) 

4) 

5) 



AS, DS, MREQ, BUSAK, and MO are output high 

ST0-ST3 and SN0-SN6 are output low 

R/W, B/W and N/S are unaffected; they retain whatever signal levels they previously had 

Dynamic memory refresh logic is disabled 



When RESET goes high again, three clock periods elapse, then two consecutive memory read machine cycles are ex- 
ecuted. The Flag and Control Word and the Program Counter are reinitialized as follows: 

Z8002 Z8001 



FCW from 0002 
PC from 0004 



FCW from 0002 

PC segment from 0004 

PC offset from 0006 



Program execution then proceeds with the program identified by the new Program Counter contents. 

THE Z8000 INSTRUCTION SET 

The Z8000 instruction set is summarized in Table 6-3. Instruction object codes and execution times are given 
alphabetically in Table 6-4. Instruction object codes are given numerically in Table 6-5. 

The most striking characteristic of the Z8000 instruction set is its orderliness. Despite its complexity, this instruc- 
tion set should be relatively easy to learn, since variations are consistent, and therefore predictable. This is in sharp 
contrast toZilog's previous offering, the Z80, which was frequently criticized for its complex and disorderly assembly 
language. 

TheZSOOO instruction set is also powerful; it at least equals that of any other 16-bit microprocessor, and will rival most 
16-bit minicomputers. 

Let us examine the Z8000 instruction set by instruction categories, as given in Table 6-3. 

All I/O ports are addressed using 16-bit I/O port addresses, which may be specified directly, or via a 16-bit 
register. Thus 65,536 I/O ports may be addressed. 

All I/O instructions have a byte version and a word version. The byte version inputs and outputs 8-bit data. The 
word version inputs and outputs 16-bit data. 8-bit data is output twice, on both halves of the 16-bit Data/Address Bus. 
Input data is read off the eight low-order Data/Address Bus lines for input instructions with odd addresses; it is read off 
the eight high-order Data/Address Bus lines for input instructions with even addresses. Note that this is the same as 
byte addressing for memory locations. 

A general characteristic of Zilog microprocessor components is the extensive use of block 
transfer logic. Instructions that repeatedly re-execute to move blocks of data occur throughout 
the Z8000 instruction set, beginning with I/O instructions. Both the byte and word versions 
of IN and OUT instructions have auto-increment and auto-decrement variations that may be illustrated as follows: 
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the byte count 
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Block transfer instructions may transfer a single data byte or word and then stop, leaving counters and pointers ready 
to handle the next byte; alternatively, instructions may transfer the entire data blocic within a single execution. In the 
latter case, interrupt requests are acknowledged between byte or word transfers; also, dynamic memory refresh cycles, 
if enabled, will be inserted at the proper time. 



Z8000 
SPECIAL I/O 
INSTRUCTIONS 
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@ris 

addr 

addrss 

addrls 

addr(ri) 

addrss(ri) 

addrls(ri) 
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The entire input and output instruction set is repeated for a set of "special" I/O instruc- 
tions. (The simple input and output instructions are repeated only for the direct I/O port varia- 
tion.) The special I/O instructions are intended for use with a Z8010 Memory Management 
Device or other special system components which may become available in the future. The 
only difference between special 1/0 instructions and normal I/O instructions is that special I/O instructions output 001 1 
via the status lines ST0-ST3. Normal I/O instructions output 0010. 

Z8000 memory reference instructions generally use one of seven memory addressing modes, 
all except the first one represented in Tables 6-3, 6-4, and 6-5 by the label adrsx. These 
seven addressing modes are: 

Mode 
Nonsegmented, implied 
Nonsegmented, direct 
Short segmented, direct 
Long segmented, direct 
Nonsegmented, indexed 
Short segmented, indexed 
Long segmented, indexed 

The operand abbreviations used above are defined prior to Table 6-3. 

Refer to the earlier description of Z8000 memory addressing modes for a more complete description of the seven 
modes summarized above. 

Although ZBOOO primary memory reference instructions generally use the seven memory ad- 
dressing modes listed above, base relative addressing, implied, indexed addressing, and pro- 
gram relative addressing options are also available. 

All primary memory reference instructions have byte and word version; most also have long 
word versions. 

Secondary memory reference instructions use only the seven memory addressing modes. 
There are byte and word versions for nearly all secondary memory reference instructions, but 
long word versions are scarce. 



ZBOOO 

PRIMARY 

MEMORY 

REFERENCE 

INSTRUCTIONS 



ZBOOO 
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MEMORY 

REFERENCE 

INSTRUCTIONS 



An anomaly of the ZBOOO instruction set is the shortage of Add-with-Carry and Subtract- 
with-Borrow instructions; they are only available as register-register operate instructions. No 
long word Add-with-Carry or Subtract-with-Borrow is available. 

Multiply and divide instructions have register-register and memory-register versions. Both have word and long 
word options. 
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The divide instruction holds the dividend in CPU registers; the divisor may reside in memory or in 
CPU registers, or it may be an immediate operand. Both the divisor and the dividend are treated as 
signed binary numbers. After the division instruction has been executed, the quotient is returned 
in the low-order half of the dividend register space, while the remainder is returned in the high- 
order half of the dividend space. A word division may be illustrated as follows: 



RR 



1 6-bit 
Registers 



1 6-bit Register, or 
2 memory bytes 



RN-1 




( RN 


PPPP 


' j RN+1 


qqqq 


RN+2 









■JIJJ 

-zzzz 




yyyy 



RN is the high-order register 

RN+1 is the low-order register 

j, p, q, y, and z represent any hexadecimal digits 

RN is a 1 6-bit register 

RR represents a 32-bit register pair, as illustrated in Figure 6-3. 

Long word division may be illustrated as follows: 

1 6-bit 
Registers 



32-bit Register, or 
4 memory bytes 



RQ, 
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vvvvwwww / (remainder = jjjjkkkk) 



Z8000 
DIVIDE 
INSTRUCTION 



j, k, p, q, s, t, V, w, X, and y represent any hexadecimal digits. 
RQ represents a 64-bit register, as illustrated in Figure 6-3. 

The sign of the remainder is always the same as the sign of the dividend. 

The divisions instruction modifies status flags as follows: 

Carry (C). If the quotient overflows or underflows, then C is set For a word divide, the quotient underflows if it is less 
than -2^5; \x overflows if it is 2^5 or more. For a long word divide, the quotient overflows if it is less than -2^^ ; it over- 
flows if it is 2^1 or more. 

Zero (Z). The Zero status is set to 1 if the quotient or divisor is 0. It is cleared otherwise. 

Sign (S). The Sign status reports the sign of the quotient; it is set if the quotient is negative; it is reset if the quotient is 
positive. 

Overflow (0). The Overflow status is set to 1 if the divisor is 0, or if the quotient cannot fit into the low-order half of the 
dividend space. 

The divide instruction's execution is aborted if the dividend high-order half absolute value is larger than the divisor ab- 
solute value. This may be illustrated as follows: 

Abort if |pppp| > |yyyy| 

Abort if |ppppqqqq| > |xxxxyyyy| 
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The multiply instruction also has word and long word versions. The multiplicand is held in CPU 
registers. The multiplier may be held in data memory, in CPU registers, or it may be provided im- 
mediately by the multiply instruction. The product is returned in CPU registers. The word option 
may be illustrated as follows: 

1 6-bit Register, or 
2 memory bytes 
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INSTRUCTION 
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p, q, y, and z represent any hexadecimal digits. 

RR represents a 32-bit register pair, as illustrated in Figure 6-3. 

Long word multiplication may be illustrated as follows: 
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32-bit Register, or 
4 memory bytes 



yyyy 



vvvvwwww • xxxxyyyy = ppppqqqqsssstttt 

p, q, s, t, V, w, X, and y represent any hexadecimal digts. 
RQ represents a 64-bit register, as illustrated in Figure 6-3. 

The multiply instruction treats all numbers as signed binary values. Status flags are adjusted as follows: 

Carry (C). C is set for overflow or underflow. For word multiplication, underflow occurs if the answer is less than -215; 
overflow occurs if the answer is 2^5 or more. For long word multiplication, underflow occurs if the product is less than 
-231; overflow occurs if the product is 23^ or more. Carry is cleared if there is no underflow or overflow. 

Zero 0. The Zero status is set if the result is 0; it is cleared otherwise. 

Sign (S). The Sign status is set for a negative result; it is reset otherwise. 

The Overflow status is always cleared. 

The LDPS instruction is somewhat unusual in that it loads both the Program Counter and the Flag 
and Control Word. Data is taken from memory as follows: 

Non-Segmented Segmented 

(Memory bytes) (Memory bytes) 



Z8000 LDPS 
INSTRUCTION 



FCW (HI) 



FCW (LO) 



PC (HI) 



PC (LO) 



00 



00 



FCW (HI) 



FCW (LO) 



PCSEG(HI) 



PCSEG(L01 



PCOFF(HI) 



PCOFF(LO) 



The LDPS jump instruction uses indirect memory addressing. 
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A subroutine CALL can use segmented implied memory addressing: 



RR 



j RN 
(RN+1 



ss 00 



xxxx 
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Z8000 

SYSTEM 

CALL 



the System Call instruction generates an interrupt acknowledge sequence. You will recall 
from the discussion of Z8000 interrupt acknowledge logic given earlier in this chapter that an in- 
terrupt identifier is pushed onto the Stack during every interrupt acknowledge sequence. For the 
System Call instruction, this identifier is the System Call instruction object code; the low-order 
byte is an 8-bit immediate data value which you specify in the instruction operand. This may be illustrated as follows: 

SC XX 

7F XXI 6 



Z8000 
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Note that the JP conditional jump instruction can use segmented implied memory ad- 
dressing. As we might expect from a Zilog high-end microprocessor, the Z8000 has a 
large number of block transfer and search instructions. These instructions come in 
groups of eight. For each type of instruction there are four word versions and four comparable 
byte versions. The four versions include an increment, an increment and repeat, a decrement, 
and a decrement and repeat. See our earlier discussion of block transfer I/O instructions for a 
general description of these four variations. 

The LDM block transfer instructions move data between a number of 16-bit registers 
and memory. You can transfer data from memory words to 16-bit registers or from 16-bit registers to memory words 
You can transfer from 1 to 16 words in a single execution. Register addressing is wrap-around. For example, the in- 
struction: 

LDM R13,THERE,6 
will transfer six words of data from memory to registers, in the following sequence: 

Memory 
THERE 
THERE+2 
THERE+4 
THERE+6 
THERE+8 
THERE+10 



Among the block transfer and search instructions there is a group of translate instructions. These are table look-up in- 
structions; they work as follows: 

TRxB @RM,@RN,RW 




1 6-blt Registers 



8-bit Memory 




RW is decremented and RM is incremented or decremented, depending on the instruction. 
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Z8000 SHIFT 
INSTRUCTIONS 



As illustrated above, the contents of the destination nnemory location serve as an 8-bit index into a memory table. The 
contents of the addressed table byte replace the index. RH1 is used, and left with an undefined value. Translate instruc- 
tions are typically used to convert characters from one code to another. For example, a single translate instruction 
could convert an EBCDIC character to an ASCII character. In this case the EBCDIC character code would constitute an 
index into a 256-byte ASCII code table. At the location specified by the EBCDIC code, you would store the ASCII 
equivalent. Executing a translate instruction would then cause the ASCII equivalent of an EBCDIC code to be loaded 
into the memory location in which the EBCDIC code had been stored. 

A variation of the Translate instruction is a Translate-and-Test, which loads the addressed table byte into Register RH1, 
but leaves it there. The Z flag is set if RH1 is 0, and Overflow is set if the counter decrements to 0. 

There are a deceptively large number of shift instructions listed in the register operate 

group. In fact, the only difference between an arithmetic and a logical left shift lies in the 

Overflow status. For an arithmetic shift this status is set if the high-order (Sign) bit changes 

following the shift: the Overflow status is cleared otherwise. Following a logical shift the Overflow status is undefined. 

For right shifts the Sign bit is replicated for arithmetic shifts, while zeros are filled in for logical shifts. 

The only difference between a dynamic shift and a non-dynamic shift is in the location of the shift bit count A dynamic 
shift takes its bit count from a CPU register. 

A non-dynamic shift takes its bit count from immediate data provided by the instruction operand. 

Note from our earlier discussion of the Z8000 Stack that the Stack address is incre- 
mented for a pop and decremented for a push. In other words, the bottom of the Stack has 
the highest memory address, and the top of the Stack has the lowest memory address. 

Four instructions control the Ml input and MO output signals. They are MBIT, MREQ, 
MRES, and MSET. 

MBIT simply inverts the level of the Ml input and returns it in the Sign status. 

MRES outputs a high signal via MO, while MSET outputs a low signal via MO. 



Z8000 STACK 
INSTRUCTIONS 



Z8000 

Ml AND MO 
INSTRUCTIONS 
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MREQ uses Ml and MO to request external access. This instruction uses Zero and Sign statuses. MREQ execution logic 
may be illustrated as follows: 



c 


Start 


1 




. 


" 






+ 






z = o 






< 


Tno 


> 


Yes 




M0= 1 




S = 
M0 = 




♦ 






c 


t 

Stop 




Decrennent 

Counter 

toO 




) 




^' 




< 


Xno 


> 


Yes 




S = 
M0 = 




S= 1 




1^ 








1 






r^ 












Z= 1 






C 


Stop 


J 


\ 





When the MREQ instruction begins execution, the Zero status is cleared; it is set to 1 after MREQ has completed execu- 
tion if a request was signalled. 

The Ml input is tested to see if the external resource being arbitrated is available. If Ml is low, then the resource is not 
available; MO is output high and the Sign status Is reset to 0. 

If Ml is being input high, then the external resource is available. MO is output low, then a time delay is inserted by 
decrementing the contents of a 16-bit register to 0. This delay givesjxternal logic time to_receive and propagate MO. 
External logic must acknowledge the resource request by inputting Ml low. In response to Ml low, MREQ sets the Sign 
status and the Zero status to 1. But if Ml is still high after the counter has decremented to 0, then MREQ outputs MO 
high, resets the Sign status toO, and sets the Zero status to 1. Therefore, following execution of the MREQ instruction, 
CPU logic interprets results as follows: 



Sign 





1 
1 
1 
1 




No request made 

Not possible 

Request made but not granted 

Not possible 

Request made and granted 
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THE BENCHMARK PROGRAM 

The Z8000 can execute our benchmark program using just three instructions. We assume the following memory 

map: 

1 6-bit 

Memory 
Locations 





NLOC 
NLOC+2 
NLOC +4 

/ 

lOBUF 

iOBUF+N 
TABLE 

1 FREE 

1 


lOBUF 




FREE 




COUNT 




1 
• 




















1 

1 


/ 




/ 




/ 




/ 


1 


must be 




moved 




\ 




\ 




\ 




\ 










1 

! 











Words 



-First Free Table Word 



Using the LDM Multiple Register Load instruction, we can initialize the addresses and word count in appropriate 
registers for an LDIR Blocl< Transfer and Repeat instruction. Finally, we update the address of the first free table word. 
Here is the necessary instruction sequence: 

ILOAD lOBUF STARTING ADDRESS INTO R1, TABLE STARTING 

lADDRESS INTO R2, WORD COUNT INTO R3 
LDM RI.NLGC, 3 

LDIR @R2, @R1, R3 IMOVE DATA BLOCK 

LD NLOC-l-2, R2 lUPDATE ADDRESS OF FIRST FREE WORD IN 

TABLE 



NLOC 



DA 
DA 
DA 



lOBUF 

FREE 

COUNT 



!l/0 BUFFER BASE ADDRESS 

IDATA TABLE FIRST FREE WORD ADDRESS 

IWORD COUNT 
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The nomenclature used to identify Z8000 registers is given in Figure 6-3. 

The following abbreviations are used in Tables 6-3, 6-4, and 6-5: 

addr any 16-bit nonsegmented address 

addrls any 32-bit long segmented address 

addrss any 16-bit short segmented address 

adrsx one of six standard memory addressing modes 

b8 immediate value in the range 0-7 

b16 immediate value in the range 0-15 

cc condition codes, as summarized in Table 6-2 

dataS 8-bit immediate data value 

data16 16-bit immediate data value 

data32 32-bit immediate data value 

disp address displacement 

FCW the Flags and Control Word 

FLAGS low-order byte of FCW 

flag any or all of C, S, P, 0, Z 

int either or both of NVI, VI 

ioaddr an I/O device 16-bit address 

(I/O) an identifier specifying that the prior address is an I/O address 

Ml the Ml signal input level 

MO the MO signal output level 

MSB the most significant (high-order) bit of any data value 

n16 immediate value in the range 1-16 

NSPOFF Normal Stack Pointer offset 

NSPSEG Normal Stack Pointer segment 

PC Program Counter 

PCOFF Program Counter offset 

PCSEG Program Counter segment 

PSAPOFF Program Status Area Pointer offset 

PSAPSEG Program Status Area Pointer segment 

rb any byte register 

rbd any byte register serving as a destination 

rbs any byte register serving as a source 

REFRESH Refresh Counter 

h any 1 6-bit index register 

rid any 1 6-bit register providing implied destination address 

hs any 16-bit register providing implied source address 

rid any 32-bit register serving as a source 

ris any 32-bit register serving as a source 

rqd any 64-bit register serving as a destination 

nw any 16-bit register 

rwd any 16-bit register serving as a destination 

rws any 16-bit register serving as a source 

SP Stack Pointer (R16 or RR14) 
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Object Code b - immediate value corresponding to b8 or b16 
c - condition code (see Table 6-2) 
d - destination register 
f - code for flags operated on: CZSP/V 
i - index or implied register. If i = no register is specified 
n - immediate value corresponding to n16 

pppp - 16-bit address word or most significant word of 32-bit address 
qqqq - least significant word of 32-bit address 
r- register 

0000 = RO, RRO, RQO, or RHO 

0001 =R1, orRHI 



0111 =R7, orRH7 

1000 = R8, RR8. RQB, or RLO 



1110 = R14, RR14, orRL6 

1111 =R15 orRL7 
s - source register 

ttttttt- 7-bit unsigned displacement 
vv - code for interrupts {VI and/or NVI) 
XX - 8-bit address displacement 
XXX - 12-bit address displacement 
xxxx - 16-bit address displacement 
yy - 8-bit immediate data 

yyyy - 16-bit immediate data or most significant word of 32-bit data 
zzzz - least significant word of 32-bit immediate data 
Statuses The Z8000 has the following status flags; 

C - Carry status 
Z - Zero status 
S - Sign status 
P - Parity status 

- Overflow status 
D - Decimal-Adjust 
H - Half-Carry 

The following symbols are used in the Status columns: 

x - flag is affected by operation 

(blank) - flag is not affected by operation 

1 - flag is set by operation 

- flag is reset by operation 

U - flag is unknown after operation 

[ [ ] ] contents of the memory location or I/O port whose address is contained in the designated register 

[] contents of memory location, I/O port, or register 

*— data is transferred in the direction of the arrow 

" ► data is exchanged between the designated locations on both sides of the arrows 

V logical OR 

A logical AND 

© logical Exclusive OR 
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Instruction Mnennonics: 

The fixed part of an assembly language instruction is shown in UPPER CASE, the variable part (immediate data, register 
name, etc.) is shown in lower case. 

Instruction Object Codes: 

Instruction words are shown as hexadecimal digits with 4-bit variable fields indicated by lower case letters (e.g., 67ib). 

Instruction words with variable fields that are not multiples of 4 bits are shown as a pair of hexadecimal digits followed 
by 8 binary bits (e.g., 7C 000001 vv) 

Instruction Execution Times: 

Tables 6-3 and 6-4 list instruction execution times in clock cycles. Real time is obtained by dividing the number of 
clock cycles by the clock speed. 

When several possible execution times are indicated (i.e., 15-19) the number of clock cycles depends on addressing 
and segmentation modes. The relationship is as follows: 

Clock Cycles = x-y 

Addressing Mode Clock Cycles 

2) addr x 

3) addrss y-3 

4) addrls y-1 

5) addr(ri) x-l-1 

6) addrss(ri) y-3 

7) addrls(ri) y 

For two execution times (i.e., 10, 15) the first is for Nonsegmented mode, the second for Segmented mode. 

Instruction times which depend on condition flags are indicated with a slash (i.e., 10, 15/7) with the first time(s) for 
condition met and the second for condition not met. 

Table 6-2. Condition Codes Used by the Z8000 Assembly Language Instruction Set 



Code 


CC Value 


Meaning 


Status Conditions 


- 


8 


Always true 


Any 


C 
ULT 


7 


Carry 

Unsigned less than 


C= 1 


EQ 

Z 


6 


Equal 
Zero 


Z= 1 


GE 


9 


Signed greater than or equal 


S®0 = 


GT 


A 


Signed greater than 


Z V (S e 0) = 


LE 


2 


Signed less than or equal 


Z V (S © 0) = 1 


LT 


1 


Signed less than 


S©0 = 


Ml 


5 


Minus 


S=1 


NC 
UGE 


F 


No Carry 

Unsigned greater than or equal 


C = 


NE 
NZ 


E 


Not equal 
Not zero 


Z = 


NOV 
PO 


C 


No overflow 
Parity is odd 


P/0 = 


PE 
OV 


4 


Parity is even 
Overflow 


P/0=1 


PL 


D 


Plus 


S = 


UGT 


B 


Unsigned greater than 


C VZ = 


ULE 


3 


Unsigned less than or equal 


C VZ = 1 
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Table 6-3. A Summary of the Z8000 Instruction Set 


Type 


Mnemonic 


Operand(s) 


rtn r 




1 


Clock 


Status 


Operation Performed 


\jp Wvuv 


^ 


Cycles 


H 


D 





p 


s 


z 


c 




IN* 


rwcl,@rw 


3Dsd 




2 


10 
















[nwd] - [[rw]](l/0) 




IN* 


rwdjoaddr 


3Bd4 


PPPP 


4 


12 
















[n«d] — [ioaddr](l/0) 
Input to 1 6-bit register rwd a data word from the I/O port addressed 
directly by ioaddr, or implied by rw. 




INB* 


rwd,@rw 


3Csd 




2 


10 
















[rbd] - [[nwlKI/O) 




INB* 


rwd.ioaddr 


3Ad4 


PPPP 


4 


12 
















[rbd] — lioaddr](l/0) 
Input to 8-bit register rbd a data byte from the I/O port addressed 
directly by ioaddr, or implied by n«. 




IND* 


@rid,@ris,rw 


3Bs8 


Ord8 


4 


21 






X 










[[rid]] - [[ris]](l/0). [rid] - [rid] - 2. [rw] - [rw] - 1 
If [rw] = then = 1. Otherwise = 0. 




INDB* 


@rid,@ris,rw 


3As8 


OrdS 


4 


21 






X 










[[rid]] - [[ris]](l/0). [rid] - [rid] - 1. [n«] - [rw] - 1 
If [rw] = then 0=1. Otherwise = 0. 

Input a 1 6-bit data word (for IND) or a data byte (for INDB) from the 
I/O port implied by ris to the memory word (for IND) or byte (for INDB) 
Implied by rid. Decrement the implied memory address in rid by 2 (for 
IND) or by 1 (for INDB). Decrement the 1 6-bit counter rw by 1 . If rw 
contains 0, set the Overflow status. 


£ 


INDR* 


@rid,@ris,rw 


3Bs8 


OrdO 


4 


21/10" 






X 










[[rid]] — [[ris]](l/0). [rid] *- [rid] - 2. [rw] — [rw] - 1 




























If [rw] = then 0=1. Otherwise reexecute. 




INDRB* 


@rid,@ris,rw 


3As8 


OrdO 


4 


21/10" 






X 










[[rid]] ^ [[ris]](l/0). [rid] - [rid] - 1 . [rw] - [rw] - 1 
If [rw] = then = 1. Otherwise reexecute. INDR and INDRB are 
identical to IND and INDB, respectively, except that INDR and INDRB 
are reexecuted until [rw] = 0. 




INI" 


@rid,@ris,rw 


3BsO 


OrdB 


4 


21 






X 










[[rid]] — [[ris]](l/0). [rid] ^ [rid] + 2. [rw] — [rw] -1 
If [rw] = then 0=1. Otherwise = 0. 




INIB* 


@rid,@ris,rw 


3AsO 


OrdS 


4 


21 






X 










[[ridll *- [[ris]](l/0). [rid] - [rid] + 1 . [rw] - [rw] - 1 
If [rw] = then 0=1. Otherwise = 0. INI and INIB are identical to 
IND and INDB, respectively, except that rid is incremented. 




INIR* 


@rid,@ris,rw 


3BsO 


OrdO 


4 


21/10" 






X 










[[rid]] - [[ris]](l/0). [rid] - [rid] + 2. [rw] *- [rw] - 1 
If [rw] = then 0=1. Otherwise reexecute. 




INIRB* 


@rid,@ris,rw 


3AsO 


OrdO 


4 


21/10" 






X 










[[rid]] — [[ris]](l/0). [rid] — [rid] + 1 . [rw] ^ [rw] - 1 
If [rw] = then 0=1. Otherwise reexecute. INIR and INIRB are iden- 
tical to IND and INDB, respectively, except that rid is incremented; 
also INIR and INIRB are reexecuted until [rw] = 0. 




OTDR* 


@rid,@ris,rw 


3BsA 


OrdO 


4 


21/10" 






X 










([rid]](l/0) — [[ris]]. [ris] — [ris] - 2. [rw] — [rw] - 1 
If [rw] ^ then reexecute. If [rw] = then = 1 and end execution. 


* Privileged instructioi 


1 — can be execi 


jted only 


in system nr 


)ode. 


" Number of clock cycl 


es depends on th 


e number of repetitior 


is for n/m"; n =minimum number of clock cycles and m = number of clock cycles added for each additional repetition 


of operation. The nu 


mber of clock cy 


ctes for 


an instruction which repeats k times is n + (k-1)i»m. 1 



Table 6-3. A Summary of the Z8000 Instruction Set (Continued) 



Type 



Mnemonic 



Operand (s) 



Op Code 



Clock 
Cycles 



Status 



H D 



S Z C 



Operation Performed 



OTDRB' 



GTIR* 
GTIRB* 



OUT* 
OUT" 



OUTB* 
OUTB* 



OUTD* 
OUTDB* 



OUT!* 
OUTIB* 



is.rw 



3AsA OrdO 



grld,@rls,rw 
?)rid,@ris,rw 



@rw,rws 
loaddr.rws 



@rw,rbs 
ioaddr.rbs 



@rid,@ris,rw 
@rid,@ris,rw 



3Bs2 OrdO 
3As2 OrdO 



3Fds 

3Bs6 pppp 



3Eds 
3As6 



pppp 



@rid,@ns,rw 
@rid,@ris,rw 



3BsA OrdS 
3AsA OrdS 



3Bs2 OrdS 
3As2 OrdS 



21/10* 



21/10" 
21/10* 



10 
12 



10 
12 



21 
21 



21 
21 



[[ridl](l/0) — [[ris]]. [ris] — [ris] - 1 . [rw] ^ [rw] - 1 
If [rw] ^0 then reexecute. If [rw] = then O = 1 and end execution. 
Output a block of 1 6-blt words (for OTDR) or S-bIt bytes (for OTDRB) 
from memory to an I/O port, rw specifies the number of words or 
bytes. Memory Is addressed, using implied memory addressing, by 
1 6-bit register ris, which is decremented after each output. 1 6-bit 
register rid specifies the I/O port. 

[[rid]](l/0) — [[ris]]. [ris] ^ [ris] + 2. [rw] ^ [rw] - 1 
If [rw] ^0 then reexecute. If [rw] = then O = 1 and end execution. 

[[rid]l(l/0) — [[ris]]. [ris] ^ [ris] + 1 . [rw] — [rw] - 1 
If [rw] ^0 then reexecute. If [rw] = then = 1 and end execution. 
OTIR and OTIRB are identical to OTDR and OTDRB, respectively, ex- 
cept that OTIR and OTIRB increment the memory address in ris. 

[IrwrnuO) ^ [rws] 

[ioaddr](l/0) — [rws] 
Output the data word from 1 6-bit register rws to the I/O port ad- 
dressed directly by ioaddr or implied by rw. 

[[rw]](l/0) - [rbs] 

[ioaddr) (I/O) — [rbs] 
Output the data byte from S-bit register rbs to the I/O port addressed 
directly by ioaddr or implied by rw. 

[[rid]](l/0) — [[ris]]. [ris] ^ [ris] - 2. [rw] ^ [rw] - 1 
If [rw] = then 0=1; otherwise = 0. 

[[rid]] (I/O) — [[ris]]. [ris] ^ [ris] - 1 . [rw] ^ [rw] - 1 
If [rw] = then 0=1; otherwise = 0. Output a data word (for 
OUTD) or byte (for OUTDB) from the memory location addressed by 
1 6-bit register ris to the I/O port addressed by 1 6-bit register rid. 
Decrement ris by 2 (for OUTD) or 1 (for OUTDB). Decrement the 
counter 1 6-bit register rw. 

[[rid]](l/0) - [[ris]]. [ris] - [ris] + 2. [rw] - [rw] - 1 . 
If [rw] = then 0=1; otherwise = 0. 

[[rid]](l/0) — [[ris]]. [ris] — [ris] + 1 . [rw] — [rw] - 1 . 
If [rw] = Othen 0=1; otherwise = 0. OUTI and OUTIB are identi- 
cal to OUTD and OUTDB, respectively, except that the memory ad- 
dress in ris is incremented. 



Privileged instruction — can be executed only in system mode. 

Number of clock cycles depends on the number of repetitions for n/m"'; n ^minimum number of clock cycles and m = number of clock cycles added for each additional repetition 

of operation. The number of clock cycles for an instruction which repeats k times is n + (k-1)>m. 



Table 6-3. A Summary of the Z8000 Instruction Set (Continued) 



Type 


Mnemonic 


Operand(s) 


Op Code 


1 

CD 


Clock 
Cycles 


Status 


Operation Performed 


H 


D 





p 


s 


z 


c 


e 

5 


SIN' 

SINB' 

SIND' 

SINDB' 

SINDR' 

SINDRB' 

SINI' 

SINIB' 

SINIR' 

SINIRB' 

SOTDR' 

SOTDRB' 

SOTIR' 

SOTIRB' 

SOUT* 

SOUTB' 

SOUTD* 

SOUTDB* 

SOUTI 

SOUTIB 


rwd.ioaddr 
rbd.ioaddr 
@rid,@ris,rw 
@rid,@ris,rw 
@rid,@ris,rw 
@rid,@ris,rw 
@rid,@ris,rw 
@rid,@ris,rw 
@rid,@ris,rw 
@rid,@ris,rw 
@rid,@ris,rw 
@rid,@ris,rw 
@rid,@ris,rw 
@rid,@ris,rw 
ioaddr,nws 
ioaddr.rbs 
@rid,@ris,rw 
@rid,@ris,rw 
@rid,@ris,rw 
@rid,@ris,rw 


3Bd5 pppp 
3 Ad 5 pppp 
3Bs9 OrdS 
3As9 OrdS 
3Bs9 OrdO 
3As9 OrdO 
3Bs1 OrdS 
3As1 OrdS 
3Bs1 OrdO 
3As1 OrdO 
SBsB OrdO 
3AsB OrdO 
3Bs3 OrdO 
3As3 OrdO 
3Bs7 pppp 
3 As 7 pppp 
SBsB OrdS 
3AsB OrdS 
3Bs3 OrdS 
3As3 OrdS 


4 
4 
4 
4 
4 
4 
4 
4 
4 
4 
4 
4 
4 
4 
4 
4 
4 
4 
4 
4 


12 
12 

21 

21 
21/10** 
21/10** 

21 

21 
21/10** 
21/10** 
21/10** 
21/10** 
21/10** 
21/10** 

12 

12 

21 

21 

21 

21 






X 
X 
X 
X 
X 
X 
X 
X 
X 
X 
X 
X 

X 
X 
X 
X 










These instructions output "special I/O" status via STO - ST3; other- 
wise, they are identical to I/O instructions as follows: 

SIN-IN<1) SINB-INB(1> 

SIND - IND SINDB - INDB 

SINDR - INDR SINDRB - INDRB 

SINI - INI SINIB - INIB 

SINIR-INIR SINIRB-INIRB 

SOTDR - OTDR DOTDRB - OTDHB 

SOTIR - OTIR SOTIRB - OTIHB 

S0UT-0UT'1> SOUTB -0UTB(1> 

SOUTD - OUTD SOUTDB - OUTDB 

SOUTI - OUTI SOUTIB - OUTIB 

(1 'Only the direct addressing option exists for the special I/O version of 
this instruction. 


» 

1 

E 

• 

l 


LD 
LD 

LD 

LD 

LDB 
LDB 


rwd.adrsx 
rwd,@ris 

rwd,ris(disp) 

rwd,ris(rw) 

rbd.adrsx 
rbd,@ris 


Slid pppp qqqq 
21 id 

3 lid xxxx 

7 lid OrOO 

60id pppp qqqq 
20id 


4/6 
2 

4 

4 

4/6 
2 


9-13 
7 

14 

14 

9-13 

7 
















[nwd] — [adrsx] 
[n«d] - [[ris]] 

Load data from the 1 6-bit memory word addressed by adrsx or [ris] 

into 1 6-bit register rwd. 
[rwd] ♦— [[ris] + disp] 

Load into 1 6-bit register rwd the contents of the 1 6-bit memory word 

addressed using base relative addressing, 
[nwd] - [[ris] + [rw]] 

Load into 1 6-bit register rwd the contents of the 1 6-bit memory word 

addressed using implied, indexed addressing, 
[rbd] — [adrsx] 
[rbd] — [[ris]] 

Load into 8-bit register rbd the contents of the memory byte ad- 
dressed by adrsx or [ris]. 


* Privileged instruction — can be executed only in system mode. 

" Number of clock cycles depends on the number of repetitions for n/m"; n =minimum number of clock cycles and m = number of clock cycles added for each additional repetition 
of operation. The number of clock cycles for an instruction which repeats k times is n + (k-1)»m. 



Table 6-3. A Summary of the Z8000 Instruction Set (Continued) 



Type 


Mnemonic 


Operand(s) 


Op Code 


1 


Clock 
Cycles 


Status 


Operation Performed 


H 


D 





P 


S 


z 


c 




LDB 


rbd,ris(disp) 


30id 


xxxx 


4 


14 
















[rbd] *- [[risl + disp] 




LOB 


rbd,ris{rw) 


70id 


OrOO 


4 


14 
















Load into 8-bit register rbd the contents of the memory byte ad- 
dressed using base relative addressing, 
[rbd] — [[ris] + [n«]] 




LDL 
LDL 

LDL 


rid.adrsx 
rld,@ris 

rld,ris(disp) 


54id 
Uid 

35id 


pppp qqqq 
xxxx 


4/6 
2 

4 


12-16 
11 

17 
















Load into 8-bit register rbd the contents of the memory byte ad.- 
dressed using implied, indexed addressing. 

[rid] — [adrsx] 

[rid] - [[ris]] 
Load into 32-bit register rid the contents of the 32-bit memory loca- 
tion addressed by adrsx or [ris]. 

[rid] — [[ris] + disp] 


• 

3 

e 

e 
o 


LDL 


rld,ris(rw) 


75id 


OrOO 


4 


17 
















Load into 32-bit register rid the contents of the 32-bit memory loca- 
tion addressed using base relative addressing, 
[rid] ^ [[ris] + [rid]] 


a 

• 
• 


LD 
LD 


adrsx.nws 
@rid,rws 


6Fis 
2Fds 


pppp qqqq 


4/6 
2 


11-15 
8 
















Load into 32-bit register rid the contents of the 32-bit memory loca- 
tion addressed using implied, indexed addressing. 

[adrsx] ♦— [rws] 

[[rid]] *- [rws] 


1 


LD 


rid(disp),rws 


33is 


xxxx 


4 


14 
















Store data from 1 6-bit register rws into memory word addressed by 
adrsx or [rid], 
[[rid] + disp] — [rws] 
Store data from 16-bit register rws into memory word addressed 




LD 


rid(rw),rws 


73is 


OrOO 


4 


14 
















using base relative addressing, 
[[rid] + [rw]] <— [rws] 


IL 


LDB 
LDB 

LDB 


adrsx.rbs 
@rid,rbs 

rid(disp),rbs 


6Eis 
2Eds 

32is 


pppp qqqq 
xxxx 


4/6 
2 

4 


11-15 
8 

14 
















Store data from 16-bit register rws into memory word addressed 

using implied, indexed addressing, 
[adrsx] <- [rbs] 
[[rid]] - [rbs] 

Store data from 8-bit register rbs into memory byte addressed by 

adrsx or [rid], 
[[rid] + disp] ^ [rbs] 

Store data from 8-bit register rbs into memory byte addressed using 

base relative addressing. 


" 


Privileged instruction — can be executed only in system mode. 

^Jumber of clock cycles depends on the number of repetitions for n/m"; n =minimum number of clock cycles and m = number of clock cycles added for each additional repetition 

af operation. The number of clock cycles for an instruction which repeats k times is n + {k-1)«m. 











Table 6-3. 


A Summary 


of the Z8000 Instruction Set (Continued) 


Type 


M nAmnnic 


Operand(s) 


Op Code 


1 


Clock 


Status 


Operation Performed 


ITIIIOIIIUIIIw 


> 


Cycles 


H 


D 





P 


S 


z 


c 






LDB 


rid(rw),rbs 


72is 


OrOO 


4 


14 
















[[rid] + [rw]] - [rbs] 
Store data from 8-bit register rbs into memory byte addressed using 
implied, indexed addressing. 




LDL 


adrsx.rls 


5Dis 


pppp qqqq 


4/6 


14-18 
















[adrsx] '— [ris] 




LDL 


@rid,rls 


1Dds 




2 


11 
















[[rid]] - [rIs] 
Store data from 32-bit register rIs into 32-bit memory long word ad- 
dressed by adrsx or [ridl. 




LDL 


rid(disp),rls 


37is 


xxxx 


4 


17 
















[[rid] + disp] — [rIs] 
Store data from 32-bit register rIs into 32-bit memory long word ad- 
dressed using base relative addressing. 




LDL 


rid(rw),rls 


77is 


OrOO 


4 


17 
















[[rid] + [rw]] — [rIs] 


1 




























Store data from 32-bit register rIs into 32-bit memory long word ad- 


3 

e 




























dressed using implied, indexed addressing. 


§ 


LDA 


rwd.adrsx 


76id 


pppp 


4 


12-13 
















[n«d] — adrsx 


O 




























Load the unsegmented address into 1 6-bit register rwd. 


• 
u 


LDA 


rid.adrsx 


76id 


pppp qqqq 


4/6 


15-16 
















[rid] — adrsx 


e 




























Load the segmented address, in segmented address format, into 32- 


1 




























bit register rid. 


K 


LDA 


rwd,ris(disp) 


34id 


xxxx 


4 


15 
















[rwd] »— [ris] + disp 


g 


LDA 


rid.risldisp) 


34id 


xxxx 


4 


15 
















[rid] *- [ris] + disp 


o 




























Load the base relative address into 16-bit register rwd (nonseg- 


s 




























mented mode) or 3 2 -bit register rid (segmented mode). 


£• 


LDA 


rwd,ris(rw) 


74id 


OrOO 


4 


15 
















[rwd] '— [ris] + [rw] 


1 


LDA 


rld,ris(rw) 


74id 


OrOO 


4 


15 
















[rid] •^ [ris] + [rw] 


£ 


LDAR 
LDAR 

LDR 
LDRB 


rwd,disp16 
rld,disp16 

rwd,disp1 6 
rbd,disp16 


340d 
340d 

310d 
300d 


xxxx 
xxxx 

xxxx 
xxxx 


4 
4 

4 
4 


15 
15 

14 
14 
















Load the implied, indexed memory address into 1 6-bit regiser rwd 

(nonsegmented mode) or 32-bit register rid (segmented mode). 
[n«d] — [PC] + disp16 

Load the program relative memory address into 1 6-bit register rwd. 
[rid] ^ [PC] + disp16 

Load the program relative segmented memory address, in segmented 

format, into 32-bit register rid. 
[n«d]«-[[PC] + disp16] 
[rbd]*-[[PC] + disp16] 


* p 


rivileged instr 


uction — can be 


executed only in system mo 


de. 


" N 


umber of cloc 


k cycles depends 


on the number of repetitions 


for n/m"; n ^minimum number of clock cycles and m = number of clock cycles added for each additional repetiition 





f operation. T 


le number of cic 


ok cycl 


9s for an instruction which repeats k times is n + (k-1)«m. 



Table 6-3. A Summary of the Z8000 Instruction Set (Continued) 



Type 


Mnenfionic 


Operand (s) 


Op Code 


• 


Clock 


Status 


Operation Performed 




> 

CO 


Cycles 


H 


D 





p 


s 


z 


c 




LDRL 


rld,disp16 


350d xxxx 


4 


17 
















[rld]^[[PC] + disp16] 


■^ 


























Load the memory word {for LDR), byte (for LDRB) or long word (for 


























LDRL) addressed using program relative addressing into the 1 6-bit, 


IJ 


























8-bit or 32-bit register. 


LDR 


disp16,rws 


330s xxxx 


4 


14 
















[[PC] + disp16] — [rwsl 


CD O 


LDRB 


disp16,rbs 


320s xxxx 


4 


14 
















[[PC] + disp16] — [rbs] 


.i S 


LDRL 


disp16,rls 


370s xxxx 


4 


17 
















[[PC] + disp16] — [ris] 


■^1 


























Load the register word (for LDR), byte (for LDRB) or long word (for 


£ 


























LDRL) into the memory location addressed using program relative ad- 
dressing. 




ADD 


rwd,@rls 


Olid 


2 


7 






X 




X 


X 


X 


[rwd] ^ [rwd] + [[ris]] 




ADD 


rwd,adrsx 


41 id pppp qqqq 


4/6 


9-13 






X 




X 


X 


X 


[rwd] •^ [rwd] + [adrsx] 
Add the contents of the addressed memory word to the 16-bit 
destination register. 




ADDB 


rbd,@rls 


OOid 


2 


7 


X 





X 




X 


X 


X 


[rbd] — [rbd] + [[ris]] 




ADDB 


rbd.adrsx 


40id pppp qqqq 


4/6 


9-13 


X 





X 




X 


X 


X 


[rbd] — [rbd] + [adrsx] 
Add the contents of the addressed memory byte to the 8-blt destina- 


i 


























tion register. 


s 


ADDL 


rld,@ris 


16id 


2 


14 






X 




X 


X 


X 


[rid] - [rid] + [[risll 


1 


ADDL 


rid.adrsx 


56id pppp qqqq 


4/6 


15-19 






X 




X 


X 


X 


[rid] — [rid] + [adrsx] 


EC 


























Add the contents of the addressed memory long word to the 32-bit 


c 


























destination register. 


i 


AND 


rwd,@ris 


07ld 


2 


7 










X 


X 




[rwd] ^ [rbd] AND [[ris]] 


2 


AND 


rwd.adrsx 


47id pppp qqqq 


4/6 


9-13 










X 


X 




[rwd] — [rbd] AND [adrsx] 


> 


























AND contents of destination 1 6-bit register with contents of memory 


■g 


























word. 


o 

o 

(0 


ANDB 


rbd,@rls 


06id 


2 


7 








X 


X 


X 




[rbd] — [rbd] AND [[ris]] 


ANDB 


rbd.adrsx 


46id pppp qqqq 


4/6 


9-13 








X 


X 


X 




[rbd] — [rbd] AND [adrsx] 




























AND contents of destination 8-bit register with contents of memory 




























byte. 




CLR 


@rid 


0Dd8 


2 


8 
















[[rid]] — 




CLR 


adrsx 


4Di8 pppp qqqq 


4/6 


11-15 
















[adrsx] — 
Clear the memory word. 




CLRB 


@rid 


OCdS 


2 


8 
















U[rid]]-0 


• 


Privileged inst 


ruction — can b( 


1 executed only in system m 


Ode. 








" r 


>Jumber of doc 


k cycles depend 


s on the number of repetition 


s for n/m"; n =mintmum number o1 


doc 


kcyc 


;les and m = number of clock cycles added for each additional repetition 


( 


if operation. 1 


'he number of cl 


ock cycles for an instruction 


which repeats k times Is n + (k-1 


•m. 







Table 6-3. A Summary of the Z8000 Instruction Set (Continued) 



Type 


Mnoinonic 


Operand(s) 


Op Code 


1 


Clock 


Status 


Operation Performed 




^ 


Cycles 


H 


D 





p 


s 


z 


c 






CLflB 


adrsx 


4Ci8 pppp 


qqqq 


4/6 


11-15 
















[adrsx] <- 
Clear the memory byte. 




COM 


©rid 


ODdO 




2 


12 










X 


X 




[[rid]] - [[rid]] 




COM 


adrsx 


4DiO pppp 


qqqq 


4/6 


15-19 










X 


X 




[adrsx] «— [adrsx] 
Ones complement the memory word. 




COMB 


@rid 


OCdO 




2 


12 








X 


X 


X 




[[rid]] - [[Fid]] 




COMB 


adrsx 


4CiO pppp 


qqqq 


4/6 


15-19 








X 


X 


X 




[adrsx] *- [adrsx] 
Ones complement the memory byte. 




CP 


rwd,@ris 


OBid 




2 


7 






X 




X 


X 


X 


[n«d] - [[ris]] 




CP 


rwd.adrsx 


4Bld pppp 


qqqq 


4/6 


9-13 






X 




X 


X 


X 


[rwd] - [adrsx] 


1 


CPB 


rbd,@ris 


OAid 




2 


7 






X 




X 


X 


X 


[rbd] - [[ris]) 


1 


CPB 


rbd.adrsx 


4Aid pppp 


qqqq 


4/6 


9-13 






X 




X 


X 


X 


[rbd] - [adrsx] 




CPL 


rld,@ris 


lOid 




2 


14 






X 




X 


X 


X 


[rid] - [[ris]] 


o 


CPL 


rid.adrsx 


50id pppp 


qqqq 


4/6 


15-19 






X 




X 


X 


X 


[rid] - [adrsx] 


• 




























Compare contents of register and memory location. Do not modify 


c 

£ 




























contents of register or memory location, but set status flags. Use 1 6- 


• 
1 




























bit register/memory word for CP, 8-bit register/memory byte for CPB, 




























32-bit register/memory long word for CPL. 


r 


CP 


@rid,data16 


ODdl yyyy 




4 


11 






X 




X 


X 


X 


[[rid]] -data 16 


E 

9 


CP 


adrsx.data 1 6 


4Di 1 yyyy 




6/8 


14-18 






X 




X 


X 


X 


[adrsx] -data 16 


s 






PPPP 


qqqq 






















£• 


CPB 


@rid,data8 


OCdl yyOO 




4 


11 






X 




X 


X 


X 


[[rid]] - dataB 


a 


CPB 


adrsx.dataS 


4Ci1 yyOO 




6/8 


14-18 






X 




X 


X 


X 


[adrsx] - dataB 


o 
o 






PPPP 


qqqq 




















Compare contents of memory location with immediate data. Do not 


« 




























modify memory location, but set status flags. Use 16-bit memory 
word for CP, 8-bit memory byte for CPB. 




DEC 


@rid,n16 


2Bdn 




2 


11 






X 




X 


X 




[[rid]]^[[rid]]-n16 




DEC 


adrsx,n16 


6Bin pppp 


qqqq 


4/6 


13-17 






X 




X 


X 




[adrsx] <— [adrsx] - n 1 6 




DECS 


@rid,n16 


2Adn 




2 


11 






X 




X 


X 




[[rid]]-[[rid]]-n16 




DECB 


adrsx.n 1 6 


6Ain pppp 


qqqq 


4/6 


13-17 






X 




X 


X 




[adrsx] ■^ [adrsx] - n 1 6 
Subtract the immediate value n 1 6 from the memory word (for DEC) 
or memory byte (for DECB) addressed by adrsx or [rid]. Values in the 
range 1-16 are subtracted. 


* 


Privileged inst 


ruction — can be 


executed only 


n system m 


ode. 






" I 


Mumber of doc 


;k cycles depend 


5 on the number of repetition 


s for n/m"; n =minimum number of 


doc 


k cycles and m = number of clock cycles added for each additional repetition 


< 


)f operation. T 


he number of cl 


ock cycles for an Instruction 


which repeats k times is n + (k-1 


•m. 















Table 6-3 


A Summary 


of the Z8000 Instruction Set (Continued) 


Type 


Mnemonic 


Operand(s) 


Opcode 


(0 


Clock 
Cycles 


Status 


Operation Performed 


H 


D 





p 


s 


z 


c 




DIV 


rld,@ris 


IBId 






2 


note 1 






X 




X 


X 


X 


Divide \ 




DIV 
DIVL 


rid.adrsx 
rqd,@ris 


5Bld 
lAld 


PPPP 


qqqq 


4/6 
2 


note 1 
note 1 






X 
X 




X 
X 


X 
X 


X 
X 


_. . >see text for a discussion of these instructions 
Divide long i 




DIVL 


rqd.adrsx 


5Ald 


PPPP 


qqqq 


4/6 


note 1 






X 




X 


X 


X 


Divide long/ 




EX 


rwd.adrsx 


6Did 


PPPP 


qqqq 


4/6 


15-19 
















[nwd] < ► [adrsx] 




EX 


rwd,@ris 


2Dsd 






2 


12 
















[rwd] ^ — [[risl] 




EXB 


rbd.adrsx 


6Cid 


PPPP 


qqqq 


4/6 


15-19 
















[rbdl — — [adrsxl 




EXB 


rbd,@ris 


2Csd 






2 


12 
















[rbdl--[[risll 
Exchange contents of the addressed memory location with the 


^ 






























selected register. Use 8-bit (for EXB) or 1 6-bit (for EX) registers and 


• 

3 






























memory locations. 


e 


INC 


@rid,n16 


29dn 






2 


11 






X 




X 


X 




[[ridl]-[[rid]] + n16 


e 
o 


INC 


adrsx,n16 


69in 


PPPP 


qqqq 


4/6 


13-17 






X 




X 


X 




[adrsx] — [adrsx] + n16 


U 


INCB 


@rid,n16 


28dn 






2 


11 






X 




X 


X 




[irid]]'-[[rid]] + n16 


S 


INCB 


adrsx.n 1 6 


68in 


PPPP 


qqqq 


4/6 


13-17 






X 




X 


X 




[adrsx] <— [adrsx] + n16 


£ 






























Add the immediate value n 1 6 to the memory word (for INC) or memo- 


% 






























ry byte (for INCB) addressed by adrsx or [rid]. Values in the range 1 - 


IC 






























1 6 are added. 


& 


MULT 


rld,@ris 


19id 






2 


note 2 











X 


X 


X 


Multiply \ 


E 
o 


MULT 
MULTL 


rid.adrsx 
rqd,@ris 


59id 
18id 


PPPP 


qqqq 


4/6 
2 


note 2 
note 2 












X 
X 


X 
X 


X 
X 


. . . . . . /See text for a discussion of these instructions 

Multiply long! 


s 


MULTL 


rqd.adrsx 


58id 


PPPP 


qqqq 


4/6 


note 2 











X 


X 


X 


Multiply long/ 


■g 


NEG 


@rid 


0Dd2 






2 


12 






X 




X 


X 


X 


[[rid]] - - [[rid]] 


8 


NEG 


adrsx 


4012 


PPPP 


qqqq 


4/6 


15-19 






X 




X 


X 


X 


[adrsx] ^ [adrsx] 


« 


NEGB 


@rid 


0Cd2 






2 


12 






X 




X 


X 


X 


[[rid]] - - [[rid]] 




NEGB 


adrsx 


4Ci2 


PPPP 


qqqq 


4/6 


15-19 






X 




X 


X 


X 


[adrsx] < [adrsx] 

Replace the contents of the memory word (for NEG) or byte (for 
NEGB) addressed by adrsx or [rid] with its twos complement. 




OR 


rwd,@rls 


05id 






2 


7 










X 


X 




[nwd] ^ [rwd] OR [[ris]] 




OR 


rwd.adrsx 


45id 


PPPP 


qqqq 


4/6 


9-13 










X 


X 




[rwd] ^ [nwd] OR [adrsx] 
OR the contents of the specified 1 6-bit register and memory word. 
Place the result in the 1 6-bit register. 




ORB 


rbd.@rls 


04id 






2 


7 








X 


X 


X 




[rbd] — [rbd] OR [[ris]] 


• 


=>rlvilegecl inst 


ruction — can be 


executed only i 


n system m 


sde. 








" r 


iJumber of cloc 


k cycles depend 


i on the number of repetition 


s for n/m"; n =minimum number of 


cloc 


kcyc 


:les and m = number of clock cycles added for each additional repetition 




3f operation. 1 


rhe number of cl 


ock eye 


les for an instruction 


which repeats k times is n + (k-1 


).m. 







Table 6-3. A Summary of the Z8000 Instruction Set (Continued) 



§1 

a c 
"SI 3 

(O O) M 



Type 


Mnemonic 


Operand (s) 


Od Coda 




1 


Clock 


Status 


Operation Performed 














>> 
m 


Cycles 


H 


D 


O 


p 


s 


z 


c 






ORB 


rbd.adrsx 


44id 


PPPP 


qqqq 


4/6 


9-13 








X 


X 


X 




[rbd] ^ [rbd] OR [adrsx] 
OR the contents of the specified 8-bit register and memory byte. 
Place the result in the 8-bit register. 




SUB 


rwd,@ris 


03id 






2 


7 






X 




X 


X 


X 


trwdl ^ [rwd] - [(risjl 




SUB 


rwd.adrsx 


43id 


PPPP 


qqqq 


4/6 


9-13 






X 




X 


X 


X 


[rwd] «— [rwd] - [adrsx] 




SUBB 


rbd,@ris 


02id 






2 


7 


X 


1 


X 




X 


X 


X 


[rbd] *- [rbd] - [[ris]] 




SUBB 


rbd.adrsx 


42id 


PPPP 


qqqq 


4/6 


9-13 


X 


1 


X 




X 


X 


X 


[rbdf^ [rbd] -[adrsx] 




SUBL 


rld,@ris 


12id 






2 


14 






X 




X 


X 


X 


[rid] - [rid] - [[ris]] 




SUBL 


rid.adrsx 


52id 


PPPP 


qqqq 


4/6 


15-19 






X 




X 


X 


X 


[rid] — [rid] - [adrsx] 
Subtract the contents of the addressed memory location from the 


• 






























selected destination register. Use 8-bit (for SUBB), 1 6-bit (for SUB) 


3 
C 






























or 32-bit (for SUBL) memory locations and registers. 


1 


TEST 


@rid 


0Dd4 






2 


8 










X 


X 


X 


[[rid]] OR 


s 


TEST 


adrsx 


4Di4 


PPPP 


qqqq 


4/6 


11-15 










X 


X 


X 


[adrsx] OR 


« 


TESTB 


@rid 


0Cd4 






2 


8 








X 


X 


X 


X 


[[rid]] OR 


i 


TESTB 


adrsx 


4Ci4 


PPPP 


qqqq 


4/6 


11-15 








X 


X 


X 


X 


[adrsx] OR 


1 


TESTL 


@rid 


ICdO 






2 


13 










X 


X 


X 


[[rid]] OR 


• 

EC 


TESTL 


adrsx 


5CiO 


PPPP 


qqqq 


4/6 


16-20 










X 


X 


X 


[adrsx] OR 


fc- 






























OR the specified memory contents with 0. Set status flags. Use a 1 6- 


1 






























bit location for TEST, an 8-bit location for TESTB, and a 32-bit loca- 


• 






























tion for TESTL. 


£• 


TSET 


@rld 


0Dd6 






2 


11 










X 






[s] — [[rid]](MSB). [[rid]] — FFFF 




TSET 


adrsx 


4Di6 


PPPP 


qqqq 


4/6 


14-18 










X 






[s] ^ [adrsx](MSB). [adrsx] ^ FFFF 


e 


TSETB 


@rid 


0Cd6 






2 


11 










X 






[s] - [[rid]](MSB). [[rid]] - FF 


(0 


TSETB 


adrsx 


4Ci6 


PPPP 


qqqq 


4/6 


14-18 










X 






[s] — [adrsx]{MSB). [adrsx] — FF 
Move the most significant bit of the memory word (for TSET) or byte 
(for TSETB) to the sign status. Then fill the word or byte with 1 bits. 




XOR 


rwd,@ris 


09id 






2 


7 










X 


X 




[n«dl - [rwdl XOR [[ris]] 




XOR 


rwd,adrsx 


49id 


PPPP 


qqqq 


4/6 


9-13 










X 


X 




[rwd] — [rwd] XOR [adrsx] 




XORB 


rbd,@ris 


OBid 






2 


7 








X 


X 


X 




[rbd] — [rbd] XOR [[ris]] 




XORB 


rbd.adrsx 


48id 


PPPP 


qqqq 


4/6 


9-13 








X 


X 


X 




[rbd] — [rbd] XOR [adrsx] 
Exclusive OR the contents of the addressed memory location and 
register. Store the result in the register. Use 16-bit memory and 
registers for XOR. Use 8-bit memory and registers for XORB. 


* 


'rivlleged Inst 


ruction — can bs 


i executed only 


n system m 


ode. 












•• r 


dumber of cioc 


:k cycles depend 


s on the number of repetition 


s for n/m"; n =minimum r 


lumt 


)ero1 


doc 


kcy( 


:les and m = number of clock cycles added for each additional repetition 


< 


jf operation. 1 


'he nunnber of cl 


ock eye 


es for an instruction 


which repeats k times is 


n + 


(k-1 


)«m. 







Table 6-3. A Summary of the Z8000 Instruction Set (Continued) 



Type 


Mnemonic 


Operand(s) 




}p Code 




5 


Clock 


Status 


Operation Performed 


■ Ft"* 












>• 
n 


Cycles 


H 


D 





p 


s 


z 


c 






LD 


rwcl,data16 


21 Od 


yyyy 




4 


7 
















[rwd]— data16 
Load 1 6-bit immediate data into 1 6-bit register rwd. 




LD 


@rid,data16 


0Dd5 


yyyy 




4 


11 
















[[rid]] ^ data 16 




LD 


adrsx,data16 


4Di5 


yyyy 
pppp 


qqqq 


6/8 


14-18 
















[adrsx] •^ data 1 6 
Load 1 6-bit immediate data into memory word addressed by adrsx or 
[rid]. 


« 


LDB 


rbd.dataS 


Cdyy 






2 


5 
















[rbd] ^ dataS 


« 






























Load immediate data byte into 8-bit register rbd. 


1 


LDB 


©rid.dataS 


0Cd5 


yyOO 




4 


11 
















[[rid]] ^ dataS 


E 


LDB 


adrsx.dataS 


4Ci5 


yyOO 




6/8 


14-18 
















[adrsx] — dataS 










PPPP 


qqqq 




















Load immediate data byte into memory byte addressed by adrsx or 
[rid]. 




LDL 


rld,data32 


140d 


yyyy 


zzzz 


6 


11 
















[rid] — data32 
Load 32-bit immediate data into 32-bit register rid. 




LDK 


rwd,b16 


BDdb 






2 


5 
















[rwdj^b16 
Load the immediate 4-bit value b16 into the low-order four bits of 
rwd. Clear the remaining twelve bits of rwd. 




PUSH 




























(See Stack operations). 




JP 


,@rid 


lEdS 






2 


10,15 
















[PC] - [[rid]] 




JP 


,adrsx 


5Ei8 


PPPP 


qqqq 


,4/6 


7-11 
















[PC] ^ [adrsx] 
Jump to the specified memory location. This is the same as a condi- 
tional jump with cc = always true. 




JR 


,disp 


ESxx 






2 


6 
















[PC] — [PC] + (disp.2) 
Jump program relative. PC is incremented to the next sequential in- 
struction before disp«2 is added as a signed binary number. This is 


a 
E 

3 






























the same as a conditional jump relative with cc = always true (blank). 


LDPS* 


@rls 


39s0 






2 


12 


X 


X 


X 


X 


X 


X 


X 


[FCW] — [[ris]]. [PC] — [[risl + 1] (nonsegmented) 


■^ 














16 


X 


X 


X 


X 


X 


X 


X 


[FCWRES] *- [[ris]]. [FCW] - [[ris] +1]. [PCSEGl - [[ris] + 2] 
[PCOFF] — [[ris] +3 ] (segmented) 




LDPS* 


adrsx 


79iO 


pppp 


qqqq 


4/6 


16-17 


X 


X 


X 


X 


X 


X 


X 


[FCW] '- [adrsx]. [PC] «- [adrsx+1] (nonsegmented) 
















20-23 


X 


X 


X 


X 


X 


X 


X 


[FCWRESl «- [adrsxj. [FCW] *- [adrsx+1 1. [PCSEGl - [adrsx+2] 
[PCOFF] — [adrsx+3] (segmented) 
Load program status and jump as described in accompanying text. 


* Privileged inst 


ruction — can ix 


executed only in system m 


Qde. 






" Number of cloc 


;k cycles depend 


5 on the number of repetition 


s for n/m"; 


n =minimum number of clock eye 


;les and m = number of clock cycles added for each additional repetiition 


of operation. 1 


'he number of cl 


ock eye 


es for ar 


1 instruction 


which repe 


ats k times is n + (k-1)«m. 





Table 6-3. A Summary of the Z8000 Instruction Set (Continued) 



Type 


Mnemonic 


Operand(s) 


Op Code 


1 


Clock 
Cycles 


Status 


Operation Performed 


H 


D 





p 


s 


z 


C 




CALL 


@rid 


IFdO 






2 


10,15 
















(1)or(2), lPC]-[[rldl] 


s 


CALL 


adrsx 


5FiO 


PPPP 


qqqq 


4/6 


12-21 
















(Dor (2), [PC] -[adrsx] 


CALR 


disp 


Dxxx 






2 


10,15 
















(1) or (2), [PC] «- [PC] - disp<'2 Program relative memory address. 


oc 






























Call the addressed subroutine, saving information on the Stack as 


s 






























follows: 


• 






























(1) [SP] — [SP] - 2, [[SP]] — [PC] 16-bit PC (nonsegmented) 


u 






























(2) [SP] *- [SP] - 4, [[SP]] — [PC] 32-bit PC (segmented) 




RET 


cc 


9E0c 






2 


10,13/7 
















If cc is "true" then [PC] — [ISP]]. [SP] — [SP] + 2 {for nonsegmented) 
































or [SP] '- [?P] + 4 (for segmented). 


1 






























If the condition code specified by cc is "true", return from subroutine. 


CO 


SC 


dataS 


7Fyy 






2 


33,39 
















System subroutine call. See accompanying text for a description of this 
instruction. 




ADD 


rwd,data16 


01 Od 


yyyy 




4 


7 






X 




X 


X 


X 


[n«d]«— [rwd] + data 16 




ADDB 


rbd,data8 


OOOd 


yyOO 




4 


7 


X 





X 




X 


X 


X 


[rbd] ^ [rbd] + dataS 




ADDL 


rld,data32 


160d 


yyyy 


zzzz 


6 


14 






X 




X 


X 


X 


[rid] ^ [rid] + data32 

Add immediate data to the destination register. Use 32-bit 
data/register for ADDL, 16-bit data/register for ADD, 8-bit 
data/register for ADDB. 




AND 


rwd,data16 


070d 


yyyy 




4 


7 










X 


X 




[n«d]*-[nwd] ANDdata16 




ANDB 


rbd.dataS 


060d 


yyOO 




4 


7 








X 


X 


X 




[rbd] — [rbd] AND dataS 


S 






























AND immediate data with destination register contents. Use 1 6-bit 


t. 






























data/register for AND, 8-bit data/register for ANDB. 


O 


CP 


rwd,data16 


OBOd 


yyyy 




4 


7 






X 




X 


X 


X 


[nNd]-data16 


(0 






























Compare 1 6-bit register contents with Immediate 1 6-bit data. Do not 


1 






























modify register contents, but save Status flags. 


E 


CPB 


rbd.dataS 


OAOd 


yyOO 




4 


7 






X 




X 


X 


X 


[rbd] - dataS 


_§ 






























Compare 8-bit register contents with immediate 8-bit data. Do not 
modify register contents, but save Status flags. 




CPL 


rld,data32 


lOOd 


yyyy 


zzzz 


6 


14 






X 




X 


X 


X 


[ridl - data32 
Compare 32-bit register contents with immediate 32-bit data. Do not 
modify register contents, but save Status flags. 




CP 




























(See secondary memory reference for memory-immediate compare in- 
structions.) 




DIV 


rld,data16 


1B0d 


yyyy 




4 


note 1 






X 




X 


X 


X 


Divide ) see accompanying text for a discussion of these 
Divide long f instructions 




DIVL 


rqd,data32 


lAOd 


yyyy 


zzzz 


6 


note 1 






X 




X 


X 


X 


• F 


'rivileged Inst 


ruction — can be 


executed only in 


system m 


3de. 




" h 


Jumber of cloc 


k cycles depend: 


> on the number of repetition 


5 for n/m"; n =minimum number of cloc 


( cycles and m = number of clock cycles added for each additional repetition 


c 


)f operation. T 


he number of cl 


3ck eye 


es for an 


instruction 


which repeats k times is n + (k-1)«m. 





Table 6-3. A Summary of the Z8000 Instruction Set (Continued) 



Type 


Mnemonic 


Operand(s) 


Op Code 


w 

S 

> 
so 


Clock 
Cycles 


Status 


Operation Performed 


H 


D 





p 


s 


z 


c 


1 
1 

1 

s 

(B 
1 

E 
E 


MULT 

MULTL 

OR 

ORB 

SUB 

SUBB 

SUBL 

XOR 
XORB 


rld.dataie 
rqd,data32 
rwd.data 16 

rbd.dataS 

rwd.data 16 
rbd.dataS 
rld.data32 

rwd.data 16 
rbd.dataS 


1 90d yyyy 

1 SOd yyyy zzzz 

050d yyyy 

040d yyOO 

030d yyyy 
020d yyOO 
1 20d yyyy zzzz 

090d yyyy 
OSOd yyOO 


4 
6 
4 

4 

4 
4 
6 

4 
4 


note 2 
note 2 

7 

7 

7 
7 
14 

7 
7 


X 


1 





X 
X 
X 


X 
X 


X 
X 
X 

X 

X 
X 
X 

X 
X 


X 
X 
X 

X 

X 
X 
X 

X 
X 


X 
X 

X 
X 
X 


Multiply » see accompanying text for a discussion of these 
Multiply long f instructions 
[rwdl'-Irwd] OR data 16 

OR the contents of the specified 1 6-bit register with the immediate 

data word, 
[rbd] — [rbd] OR dataS 

OR the contents of the specified S-bit register with the immediate 

data byte, 
[rwd] '— [rwd] - data 1 6 
[rbd] — [rbd] - dataS 
[rid] ^ [rid] - data32 

Subtract immediate data from the destination register. Use 32-bit 

data/register for SUBL. 16-bit data/register for SUB. S-bit 

data/register for SUBB. 
[rwd] ^ [rwd] XOR data 16 
[rbd] — [rbd] XOR dataS 

Exclusive-OR the contents of the register with immediate data. Store 

the result in the register. Use 1 6-bit register and data for XOR. Use 8- 

bit register and data for XORB. 


e 
o 

1 

o 

o 

c 
o 

a. 
E 

3 
g 

2 
m 


DJNZ 
DBJNZ 


rw.disp 
rb.disp 


Fr Ittttttt 
Fr Ottttttt 


2 
2 


11 
11 
















[rw] — Ion] - 1 . [PC] — [PC] + 2. If [rw] is not 0. then 

[PC] - [PC] - [disp.2] 

[rb] — [rb] - 1 . [PC] — [PC] + 2. If [rb] is not 0, then 

[PC] - [PC] - [disp.2] 
Decrement a 1 6-bit register (for DJNZ) or an 8-bit register (for DB- 
JNZ). Increment the Program Counter as per normal operation. If the 
decremented register contents is not 0. then subtract twice the dis- 
placement, as an unsigned binary number, from the incremented Pro- 
gram Counter, causing a branch back to a lower program memory ad- 
dress. If the decremented register contents is 0. continue execution 
with the next instruction. 


* Privileged instruction — can be executed only in system mode. 

•* Number of clock cycles depends on the number of repetitions for n/m"; n =minimum number of clock cycles and m = number of clock cycles added for each additional repetition 
of operation. The number of clock cycles for an instruction which repeats k times is n + {k-1).m. 



Table 6-3. A Summary of the Z8000 Instruction Set (Continued) 



(O 



Type 


Mnemonic 


Operand(s) 


Op Code 


CD 


Clock 
Cycles 


Status 


Operation Performed 


H 


D 





p 


s 


z 


C 


§1 
|1 

M 

s -i 
"1 

u 


JP 
JP 

JR 


cc,@rld 
cc.adrsx 

cc.disp 


lEdc 

5Eic pppp qqqq 

Ecxx 


2 

4/6 

2 


10,15/7 
7-11 

6 
















If cc is true, [PC] — [[rid]] 
If cc Is true. [PC] «— [adrsx] 

Jump to the memory location specified by adrsx or [rid] if condition 

code cc is true. 
If cc is true. [PC] ^ [PC] + (disp.2) 

Jump program relative if condition code is true. PC is incremented to 

address the next sequential instruction before disp*2 Is added as a 

signed binary number. 


« 

ss 

•II 


EX 
EXB 

LD 

LDB 

LDL 


rwd.rws 
rbd.rbs 

rwd.rws 
rbd.rbs 
rid.rls 


ADsd 
ACsd 

A1sd 
AOsd 
94sd 


2 
2 

2 
2 
2 


6 
6 

3 
3 
5 
















[rwd] ' ► [rws] 

[rbdl — — [rbs] 

Exchange registers' contents for 1 6-blt (EX) or 8-bit (EXB) registers, 
[rwd] «— [rws] 
[rbd] — [rbs] 
[rid] — [ris] 

Move data between any two 1 6-bit registers (for LD), 8-bit registers 

(for LDB) or 32-bit registers (for LDL). 


o 

i 

(0 

■o 
e 

10 

S 

H 

1 

s 


CPD 
CPDB 

CPDR 
CPDRB 


rwd.@ris,rw.cc 
rbd.@ris.rw.cc 

rwd,@ris,rw.cc 
rbd,@ris,rw.cc 


BBsB Ordc 
BAsB Ordc 

BBsC Ordc 
BAsC Ordc 


4 
4 

4 
4 


20 
20 

20/9" 
20/9" 






X 
X 

X 
X 




u 
u 

u 
u 


X 
X 

X 
X 


u 
u 

u 
u 


[rwd] - [[rIs]]. If cc true. Z = 1 . If cc false, Z = 

[ris] «- [ris] - 2. [rw] «— [rw] - 1 . If [rw] = 0. = 1 otherwise = 0. 

[rbd] - [[ris]]. If cc true. Z = 1 . If cc false, Z = 0. 

[ris] '— [ris] - 1 . [rw] — [rw] - 1 . If [rw] = 0, = 1 otherwiseO = 0. 
Search a string for a condition. Compare a word in rwd (for CPD) or a 
byte In rbd (for CPDB) with the next word (for CPD) or byte (for CPDB) 
in a memory string, using implied memory addressing. Register and 
memory contents are not modified, nor are Status flags changed, but 
status conditions are compared with cc. If cc is true. Z is set to 1 ; 
otherwise Z Is reset to 0. Decrement the Implied memory address in 
ris by 2 for CPD. or by 1 for CPDB. Decrement 1 6-blt counter rw by 1 . 
If rw is 0. set to 1 ; otherwise reset to 0. 

See CPD. 

See CPDB. 

CPD and CPDB are identical to CPD and CPDB. respectively, except 
that instruction execution is repeated until either Z or status is 1 . In- 
terrupts will be acknowledged between reexecutions. 


* Privileged instruction — can be executed only in system mode. 
" Number of clock cycles depends on the number of repetitions for n/m"; n ^minimum number of clock cycles and m = number of clock cycles added for each additional repetition 
of operation. The number of clock cycles for an instruction which repeats k times is n + (k-1)>m. 



Table 6-3. A Summary of the Z8000 Instruction Set (Continued) 



Type 


Mnemonic 


Operand(s) 


Op Code 


s 

> 

CO 


Clock 
Cycles 


Status 


Operation Performed 


H 


D 





p 


s 


z 


c 




CPI 


rwd,@rls,rw,cc 


BBsO 


Ordc 




4 


20 






X 




u 


X 


u 


[rwd] - [[risl]. If cc true, Z = 1 . If cc false, Z = 0. 

[ris] «- [ris] + 2. [rw] — [rwl - 1 . If [rw] = 0, = 1 ; otherwise = 0. 




CRIB 


rbd,@ris,rw,cc 


BAsO 


Ordc 




4 


20 






X 




u 


X 


u 


[rbd] - [[ris]]. If cc true, Z = 1 . If cc false, Z = 0. 

[ris] «- [ris] + 1 . [rw] — [rw] - 1 . If [n«] = 0, = 1 ; otherwise = 0. 
CPI and CPIB are identical to CPD and CPDB, respectively, except that 
the implied memory address in ris is inci-emented by 2 for CPI, or by 1 
for CPIB. 




CPIR 


rwd,@rls,rw,cc 


BBs4 


Ordc 




4 


20/9" 






X 




u 


X 


u 


See CPI. 




CPIRB 


rbd,@ris,rw,cc 


BAs4 


Ordc 




4 


20/9" 






X 




u 


X 


u 


See CPIB. 
CPIR and CPIRB are identical to CPD and CPDB, respectively, except 


^ 






























that the implied memory address in ris is incremented by 2 for CPI, or 


• 

3 






























by 1 for CPIB, and instruction execution is repeated until either Z or 


e 






























status is 1. Interrupts will be acknowleged between reexecutions. 


o 


CPSD 


@rid,@rls,rw,cc 


BBsA 


Ordc 




4 


25 






X 




u 


X 


u 


[[rid]] - ([ris]]. If cc true, Z = 1 . If cc false, Z = 0. 


" 






























[rid] - [rid] - 2. [ris] - [ris] - 2. [rw] - [rw] - 1 . 


£ 

S 






























If [rw] = 0, = 1 ; otherwise = 0. 


S 


CPSDB 


@rid,@ris,rw,cc 


BAsA 


Ordc 




4 


25 






X 




u 


X 


u 


[[rid]] - [[ris]]. If cc true, Z = 1 . If cc false, Z = 0. 


(0 

■o 






























[rid] — [rid] - 1 . [ris] *- [ris] - 1 . [rw] ^ [rw] - 1 . 


e 

(0 






























If [rw] = 0, = 1 ; otherwise = 0. 


£ 






























Compare two strings for a condition. Compare the next word (for 


•I 

e 






























CPSD) or byte (for CPSDB) in a source string with the next word (for 
































CPSD) or byte (for CPSDB) in a destination string. Both strings are ad- 


8 






























dressed using implied memory addressing. No memory contents are 






























modified, nor are any Status flags changed, but status conditions are 
































compared with cc. If cc is true, Z is set to 1 . Otherwise Z is reset to 0. 
































Decrement the implied memory addresses in ris and rid by 2 for 
































CPSD, or by 1 for CPSDB. Decrement 1 6-bit counter rw by 1 . If rw is 
































0, set to 1 . Otherwise reset to 0. 




CPSDR 


@rid,@ris,rw,cc 


BBsE 


Ordc 




4 


25/14" 






X 




u 


X 


u 


See CPSD. 




CPSDRB 


@rid,@ris,rw,cc 


BAsE 


Ordc 




4 


25/14" 






X 




u 


X 


u 


See CPSDB. 
CPSDR and CPSDRB are identical to CPSD and CPSDB, respectively, 
except that the instructions are reexecuted until either Z or status is 
1 . Interrupts are acknowleged between reexecutions. 


* Privileged inst 


ruction — can be executed only in 


system m( 


3de. 




" Number of cloc 


;k cycles depends on the number of repetition; 


s for n/m**; n =minimum number of clock eye 


les and m = number of clock cycles added for each additional repetition 


of operation. 1 


'he number of clock cycles for an 


instruction 


which repeats k times is n + (k-1)«m. 











Table 6-3 


A Summary of the Z8000 Instruction Set (Continued) 


Type 


Mnemonic 


Operand(s) 


Op Code 


S 


Clock 


Status 


Operation Performed 




Cycles 


H 


D 





p 


s 


z 


c 




CPSI 


@rld,@ris,rw,cc 


BBs2 Ordc 


4 


25 






X 




u 


X 


u 


[[rid]] - [[ris]]. If cc is true Z = 1 . If cc is false, Z = 0. 
[rid] - [rid] + 2. [ris] ^ [ris] + 2. [rw] *- [rw] - 1 . 
If [rw] = 0, = 1 ; otherwise = 0. 




CPSIB 


@rid,@ris,rw,cc 


BAs2 Ordc 


4 


25 






X 




u 


X 


u 


[[rid]] - [[ris]]. If cc is true, Z = 1 . If cc Is false, Z = 0. 

[rid] ^ [rid] + 1 . [ris] ^ [ris] + 1 . [nw] — [rw] - 1 . 
If [rw] = 0, = 1 ; otherwise = 0. 

CPSI and CPSIB are identical to CPSD and CPSDB, respectively, ex- 
cept that the implied memory addresses in rid and ris are incremented 
by 2 {for CPSI) or by 1 (for CPSIB). 




CPSIR 


@rid,@rls,rw,cc 


BBs6 Ordc 


4 


25/14" 






X 




u 


X 


u 


See CPSI. 


~ 


CPSIRB 


@rid,@ris,rw,cc 


BAs6 Ordc 


4 


25/14" 






X 




u 


X 


u 


See CPSIB. 


3 


























CPSIR and CPSIRB are identical to CPSD and CPSDB, respectively. 


C 


























except that the implied memory addresses in rid and ris are incre- 


1 


























mented by 2 (for CPSIR) or by 1 (for CPSIRB) and the instructions are 


w 


























reexecuted until either Z or status is 1 . Interrupts are acknowleged 


o 


























between reexecutions. 


(0 


LDD 


@rid,@ris,rw 


BBs9 OrdS 


4 


20 






X 










[[rid]] *- [[ris]]. [rid] *- [rid] - 2. [ris] - [ris] - 2. 


























Ion] — [nw] - 1 . If [rw] = 0, = 1 ; otherwise = 0. 


s 


LDDB 


@rid,@ris,rw 


BAs9 OrdS 


4 


20 






X 










[[rid]] - [[ris]]. [rid] *- [rid] - 1 . [ris] - [ris] - 1 . 


• 


























[rw] ^ [rw] - 1 . If [n«] = 0, = 1 ; othenwise = 0. 


M 

e 
a 


























Transfer a word (for LDD) or a byte (for LDDB) from the memory loca- 


.? 


























tion addressed by register ris to the memory location addressed by 


IS 


























rid. Decrement addresses in rid and ris by 2 (for LDD) or 1 (for LDDB). 


O 

s 


























Decrement the counter rw by 1 . If rw contains 0, set the Overflow 
status to 1 . 




LDDR 


@rid,@ris,rw 


BBs9 OrdO 


4 


20/9" 






1 










[[ridll — [[ris]]. [rid] — [rid] - 2. [ris] — [ris] - 2. 
[rw] — [rw] - 1 . If [rw] ^ 0, reexecute. 
If [rw] = 0, = 1 and end execution. 




LDDRB 


@rid,@ris,rw 


BAs9 OrdO 


4 


20/9" 






1 










[[rid]] - [[ris]]. [rid] - [rid] - 1 . [ris] - [ris] - 1 . 

[rw] <— [rw] - 1 . If [rw] t^ 0, reexecute. 
If [rw] = 0, = 1 and end execution. 

LDDR and LDDRB are identical to LDD and LDDB, respectively, except 
that LDDR and LDDRB reexecute until rw has decremented to 0. 




LDI 


@rld,@ris,rw 


BBs1 OrdS 


4 


20 






X 










[[rid]] ^ [[ris]]. [rid] — [rid] + 2. [ris] — [ris] + 2. 

[rw] <— [rw] - 1 . If [rw] = then 0=1; othenwise = 0. 


* Privileged instruction — can be executed only in system mode. 


" Number of clock cycles depends on the number of repetitions for n/m"; n =minimum number of clock cycles and m = number of clock cycles added for each additional repetition 


of operation. The number of clock cycles for an instruction which repeats k times is n -i- (k-1)«m. 









Table 6-3 


. A Summary of the Z8000 Instruction Set (Continued) 










S 


Clock 


Status 




Type 


Mnemonic 


Operand(s) 


Op Code 


a 


Cycles 




Operation Performed 


H 


D 





p 


s 


z 


c 




LOIB 


@rid,@ris,rw 


BAs1 OrdS 


4 


20 






X 










[[rid]] — [[risU. [rid] — [rid] + 1 . [ris] — [ris] + 1 . 

[rw] '- [n«] - 1 . If [rw] = 0, then 0=1; othenwise = 0. 
LDI and LDIB are identical to LDD and LDDB, respectively, except that 
the source and destination addresses ris and rid are incremented by 2 
(for LDI) or 1 (for LDIB). 




LDIR 


@rid,@ris,rw 


BBs1 OrdO 


4 


20/9" 






1 










[[rid]] - [[ris]]. [rid] - [rid] + 2. [ris] - [ris] + 2. 
[rw] — [vn] - 1 . If [rw] ^ then reexecute. 
If [rw] = then = 1 and end execution. 




LDIRB 


@rid,@ris,rw 


BAsI OrdO 


4 


20/9" 






1 










[[rid]] — [[ris]]. [rid] — [rid] + 1 . [ris] ^ [ris] + 1 . 
[rw] <— [rw] - 1 . If [rw] ^ then reexecute. 


— 


























If [rw] = then = 1 and end execution. 


1 


























LDIR and LDIRB are identical to LDD and LDDB, respectively, except 


•I 


























that the source and destination addresses ris and rid are incremented; 


§ 


























also, LDIR and LDIRB are reexecuted until rw decrements to 0. 


O 


LDM 


rwd,@ris,n16 


ICsl OdOn 


4 


14/3" 
















[rwd] ♦— [[ris]] do n 1 6 times incrementing register and memory ad- 


u 


























dresses 


S 

(0 


LDM 


rwd,adrsx,n16 


5Ci1 OdOn 


6/8 


17-21/3" 
















[nwd] ■^[adrsx] do n16 times incrementing register and memory ad- 


1 






pppp qqqq 




















dresses 


g 


























Move a block of n1 6 memory words from memory to 1 6-bit registers. 


5 


























adrsx or @ris addresses the first, lowest addressed memory word. 


w 

c 

(0 


























rwd addresses the first 1 6-bit register. n1 6 can have any value from 


H 


























1 to 1 6. (See accompanying text for more details.) 


o 


LDM 


@ris,rws,n16 


1 Cd9 OsOn 


4 


14/3" 
















[[ris]] «— [rws] do n16 times incrementing register and memory ad- 


o 

s 


























dresses 


LDM 


adrsx,rws,n16 


5Ci9 OsOn 


6/8 


17-21/3" 
















[adrsx] «— [rws] do n16 times incrementing register and memory ad- 








pppp qqqq 




















dresses 
This instruction is identical to the one above, except that data moves 
from registers to memory. Register contents are not affected. 




TRDB 


@rid,@ris,rw 


BBdS OrsO 


4 


25 






X 






u 




[[rid]] - [[ris] + [[rid]]], [rw] - [rw] - 1 . [rid] - [rid] - 1 . 
Translate a memory byte, as described in the accompanying text. 
Decrement the destination address in rid and the byte counter in rw. If 
rw = 0, set to 1 . If n« ?t o, reset to 0. Byte register RH1 contents 
is lost. 


• p 


rivileged instr 


action — can be executed only in system mode. 


" N 


umber of clocl' 


c cycles depends on the number of repetitions for n/m"; n =minimum number of clock cycles and m = number of clock cycles added for each additional repetition 


of operation. The number of clock cycles for an instruction which repeats k times is n + (k-1)«m. 1 



Table 6-3. A Summary of the Z8000 Instruction Set (Continued) 



3) 
(D 

< 
> 

si 

a. c 

«a 3 

<0 Q) t>i 



Type 


Mnemonic 


Operand(s) 


Op Code 


1 


Clock 


Status 


Operation Performed 
























00 


Cycles 


H 


D 





p 


s 


z 


C 






TRDRB 


@rid,@ris,rw 


BSdC OrsO 


4 


25/14" 






1 






u 




[[ridl] - [[ris] + ([rid]]], [rv*] - [nw] - 1 . [rid] *- [rid] - 1 . 
If [rw] = 0, = 1 and end execution. If [rwl ?to, reexecute. 
This instruction is identical to TRDB, except the instruction is reex- 
ecuted until [rw] = 0. 




TRIB 


@rid,@ris,rw 


BBdO OrsO 


4 


25 






X 






u 




[[rid]] - [[ris] + [[ridllJ. [rw] - [n«] - 1 . [rid] ^ [rid] + 1 
TRIB is identical to TRDB except that the destination address in rid is 
incremented. 




TRIRB 


@rid,@ris,rw 


B8d4 OrsO 


4 


25/14" 






1 






u 




[[rid]] — [[ris] + [[rid]]], [rw] — [n«] - 1 . [rid] — [rid] + 1 . 
If [rw] = 0, = 1 and end execution. If [rw] 4= 0, reexecute. 
TRIRB is identical to TRDB except that the destination address in rid 


_ 


























is incremented; also, TRIRB is reexecuted until [rw] = 0. 


• 


TRTDB 


@rid,@ris,rw 


BSdA OrsO 


4 


25 






X 






X 




[RH1 ] - [[ris] + [[rid]]], [rw] - [nw] - 1 . [rid] - [rid] - 1 . 


e 


























Load a table byte into 8-bit register RH 1 , as described in the accom- 


g 


























panying text. Reset Z status to if [RH1] ^0. Set Z status to 1 if 


O 


























[RH 1 ] = 0. Decrement destination address rid and byte counter rw. If 




























rw = 0, 0= 1. If nw?tO, = 0. 


s 


TRTDRB 


@rid,@ris,rw 


BBdE OrsE 


4 


25/14" 






X 






X 




[RH1] - [[ris] + [[rid]]], [rw] - [n«] - 1. [rid] - [rid] - 1 


(0 


























If [rw] = 0, = 1. If [rw] ^0, = 0. If [RH1] = 0, Z = 1; otherwise 


(0 


























Z = 0. TRTDRB is identical to TRTDB except that TRTDRB is re- 


5 


























executed until 0=1 or Z = 0. 


s 


TRTIB 


@rid,@ris,rw 


B8d2 OrsO 


4 


25 






X 






X 




[RH1] — [[ris] + [[rid]]], [nw] ^ [nw] - 1 . [rid] *- [rid] + 1 


2 


























TRTIB is identical to TRTDB except that TRTIB increments the 


























destination address in rid. 


s 


TRTIRB 


@rld,@ris,rw 


B8d6 OrsE 


4 


25/14" 






X 






X 




[RH1] — [[ris] + [[rid]]], [rw] — [n«] - 1. [rid] — [rid] + 1 


s 


























If [rw] = 0, = 1 . If [rw] ^0, = 0. If [RH1] = 0, Z = 1 ; otherwise 
Z = 0. TRTIRB is identical to TRTDB except that TRTIRB increments 
the destination address in rid and reexecutes until 0=1 or Z = 0. 


* Privileged instruction — can be executed only in system mode. | 


" Number of clock cycles depends on the number of repeti 


tions for n/m"; n =minimum number of clock cycles and m = number of clock cycles added for each additional repetition 1 


of operation. The number of clock cycles for an instruction which repeats k times is n + (k-1 )»m. 1 



Table 6-3. A Summary, of the Z8000 Instruction Set (Continued) 



Type 


Mnemonic 


Operand(s) 


Opcode 


• 

>• 


Clock 
Cycles 


Status 


Operation Performed 


H 


D 





p 


s 


z 


C 




ADC 


rwd.rws 


B5sd 


2 


5 






X 




X 


X 


X 


[nwd] — [rwd] + [rws] + C 




ADCB 


rbd.rbs 


B4sd 


2 


5 


X 





X 




X 


X 


X 


[rbd] ^ [rbd] + [rbs] + C 
Add the source register contents plus the initial Carry to the destina- 
tion register. Use 1 6-bit registers for ADC. Use 8-bit registers for 
ADCB. 




ADD 


rwd.rws 


81sd 


2 


4 






X 




X 


X 


X 


[rwd] — [rwd] + [rws] 




ADDB 


rbd.rbs 


SOsd 


2 


4 


X 





X 




X 


X 


X 


[rbd] — [rbd] + [rbs] 




ADDL 


rid.rls 


96sd 


2 


8 






X 




X 


X 


X 


[rid] — [rid] + [ris] 
Add the Source register contents to the Destination register. Use 32- 
bit registers for ADDL. 1 6-bit registers for ADD and 8-bit registers for 
ADDB. 




AND 


rwd.rws 


87sd 


2 


4 










X 


X 




[rwd] •^ [rwd] AND [rws] 




ANDB 


rbd.rbs 


86sd 


2 


4 








X 


X 


X 




[rbd] — [rbd] AND [rbs] 


ID 


























AND the Source register contents with the Destination register con- 


1 


























tents. Use 1 6-bit registers for AND and 8-bit registers for ANDB. 


o 


CP 


rwd.rws 


8Bsd 


2 


4 






X 




X 


X 


X 


[nwd] - [rws] 


1 


























Compare 1 6-bit register contents by subtracting the Source register 


M 

'5i 


























from the Destination register values. Do not modify any register con- 


£ 


























tents, but set Status flags. 


k 


CPB 


rbd.rbs 


8Asd 


2 


4 






X 




X 


X 


X 


[rbd] - [rbs] 




























Compare 8-bit register contents by subtracting the Source register 


1 


























from the Destination register values. Do not modify any register con- 
tents, but set Status flags. 




GPL 


rid.rls 


SOsd 


2 


8 






X 




X 


X 


X 


[rid] - [rIs] 
Compare 32-bit register contents by subtracting the Source register 
from the Destination register values. Do not modify any register con- 
tents, but set Status flags. 




DIV 
DIVL 


rid.nws 
rqd.rls 


9Bsd 
9Asd 


2 
2 


note 1 
note 1 






X 
X 




X 
X 


X 
X 


X 
X 


^. ._, , see text for a discussion of these instructions 
Divide long 




MULT 
MULTL 


rid.rws 
rqd.rls 


99sd 
98sd 


2 
2 


note 2 
note 2 












X 
X 


X 
X 


X 
X 


.. .... . see text for a discussion of these instructions 

Multiply long) 


* Privileged instr 


uction — can be executed only in systet 


Ti mo 


de. 








" Number of cloc 
of operation. T 


k cycles depends on the number of repet 
he number of clock cycles for an instru( 


tions 
:tion 


forn/m"; n =minimum number of 
which repeats k times is n + (k-1) 


clock 
•m. 


cycl 


es and m = number of clock cycles added for each additional repetition 









Table 6-3. 


A Summary 


Df the Z8000 Instruction Set (Continued) 
















Type 




Operand(s) 


Op Code 


(0 

« 


Clock 


Status 


Operation Performed 




>> 

CO 


Cycles 


H 


D 





p 


s 


z 


c 




OR 


rwd.rws 


85sd 




2 


4 










X 


X 




[n«d] — [rwd] OR [rws] 




ORB 


rbd.rbs 


84sd 




2 


4 








X 


X 


X 




[rbd] «- [rbd] OR [rbs] 
OR the contents of the Source register with the Destination register 
contents. Use 1 6-bit registers for OR and 8-bit register for ORB. 




RLDB 


rbd.rbs 


BEsd 




2 


9 






u 




X 


X 




Left rotate BCD digits in two 8-bit registers specified by rbd and rbs. 
The same register cannot be specified for rbd and rbs. Digits are ro- 
tated as follows: 


1 

3 
C 




























JL 

765432 10 76543210 


*d| II 1 





1 1 1 1 1 1 I'bs 




— ^,, -i»^- - — ^-il»- 


O 

O 
• 




























1 ♦ 


S 


RRDB 


rbd.rbs 


BCsd 




2 


9 






u 




X 


X 




Right rotate BCD digits in two 8-bit registers specified by rbd and rbs. 


a. 
O 




























The same register cannot be specified for rbd and rbs. Digits are ro- 


1 




























tated as follows: 


1 

1 
5) 




























7 6 543210 765 43 2 10 


rbdQ 




















1 II 1 1* 1 


~ —^—f- 




SBC 


rwd.rws 


B7sd 




2 


5 






X 




X 


X 


X 


[nwd] — [rwd] - [rws] - C 




SBCB 


rbd.rbs 


B6sd 




2 


5 


X 


1 


X 




X 


X 


X 


[rbd] — [rbd] - [rbs] - C 
Subtract the Source register contents, plus the initial Carry, from the 
Destination register contents using twos complement arithmetic. Use 
1 6-bit registers for SBC. Use 8-bit registers for SBCB. 


* Privileged instruction — can be executed only in 


system mode. 1 


" Number of clock cycles depends on the number of repetitions for n/m**; n =minimum number of clock cycles and m = number of clock cycles added for each additional repetition | 


of operation. The number of clock cycles for an 


instruction which repeats k times is n + (k-1)»m. 1 



Table 6-3. A Summary of the Z8000 Instruction Set (Continued) 



Type 


Mnemonic 


Operand (s) 


Op Code 


M 


Clock 
Cycles 


Status 


Operation Performed 


H 


D 





p 


s 


z 


c 


.s = 

• 1 

to 

9 
w 

ee 


SUB 

SUBB 

SUBL 

XOR 
XORB 


rwd.rws 
rbd.rbs 
rid.rls 

rwd.rws 
rbd.rbs 


83sd 
82sd 
g2sd 

89sd 
88sd 


2 
2 
2 

2 
2 


4 
4 
8 

4 
4 


X 


1 


X 
X 
X 


X 


X 
X 
X 

X 
X 


X 
X 
X 

X 
X 


X 
X 
X 


[rwd] •^ [n«d] - [rws] 
[rbd] — [rbd] - [rbs] 
[rid] — [rid] - [ris] 

Subtract the Source register contents from the Destination register. 

Use 32-bit registers for SUBL. 16-bit registers for SUB, 8-bit 

registers for SUBB. 
[rwd] ^ [rwd] XOR [rws] 
[rbd] ^ [rbd] XOR [rbs] 

Exclusive-OR the contents of Source and Destination registers. Store 

the result in the Destination register. Use 1 6-bit registers for XOR. 

Use 8-bit registers for XORB. 


(0 

I 

O 

• 
m 
'5) 

e 
oc 


CLR 

CLRB 

COM 

COMB 

DAB 
DEC 
DECB 

EXTS 

EXTSB 

EXTSL 


rwd 

rbd 

rwd 

rbd 

rbd 
rwd.nie 
rbd.nie 

rid 

rwd 

rqd 


8Dd8 

8Cd8 

8DdO 

8CdO 

BOdO 
ABdn 
AAdn 

BIdA 

BIdO 

B1d7 


2 

2 

2 

2 

2 
2 
2 

2 

2 

2 


7 
7 
7 

7 

5 
4 
4 

11 

11 

11 






X 
X 




X 
X 
X 


X 
X 
X 


X 


[md] — 

Clear the Selected Word register, 
[rbd] — 

Clear the Selected Byte register, 
[rwd] — [fwB] 

Complement the Selected Word register, 
[rbd] — [rbd] 

Complement the Selected Byte register. 
Decimal adjust contents of 8-bit register rbd. 
[rwd]^[rwd]-n16 
[rbd]^[rbd]-n16 

Subtract the immediate value n1 6 from a 1 6-bit register (for DEC) or 

an 8-bit register (for DECB). 
Bits 16 to 31 of [rid] —bit 15 of [rid]. 

The sign bit of the low-order word of the register pair Is copied into 

all bits of the high-order word of the register pair. 
Bits 8 to 1 5 of [rwd] — bit 7 of [rwd] 

The sign bit of the low-order byte of the register is copied into all bits 

of the high-order byte of the register. 
Bits 32 to 63 of [rqd] — bit 31 of [rqd] 

The sign bit of the low-order register pair of the Quadruple register is 

copied into all bits of the high-order register pair. 


* Privileged instruction — can be executed only in system mode. 

" Number of clock cycles depends on the number of repetitions for n/m"; n =minimum number of clock cycles and m = number of clock cycles added for each additional repetition 
of operation. The number of clock cycles for an instruction which repeats k times is n + (k-1)>m. 



Table 6-3. A Summary of the Z8000 Instruction Set (Continued) 



Type 



Mnemonic 



Operand(s) 



Op Code 



Clock 
Cycles 



Status 



H D P S Z C 



Operation Performed 



INC 
INCB 



NEG 
NEGB 



RL 
RL 
RLB 
RLB 



RLC 
RLC 
RLCB 
RLCB 



rwd,n16 
rbd,n16 



rwd 
rbd 



rwd,1 
rwd, 2 
rbd,1 
rbd,2 



A9dn 
ABdn 



8Dd2 
8Cd2 



B3d8 
B3dA 
B2d8 
B2dA 



rwd,1 


B3d0 


n«d,2 


B3d2 


rbd.l 


B2dO 


rbd,2 


B2d2 



[rwd] — [rwd] +n16 
[rbd] — [rbd] + n16 

Add the immediate value n1 6 to a 1 6-bit register (for INC) or an 8-bit 

register (for INCB). 

[rwd] ' [rwd] 

[rbd] — - [rbd] 

Replace the contents of the 1 6-bit register (for NEG) or 8-bit register 

(for NEGB) with its twos complement. 
Left rotate contents of word (for RL) or byte (for RLB) register, n bits 

(n = 1 or 2), as follows: 



raJr 



B-if 



5 



? 



See accompanying text for a discussion of the Overflow status for all 
Register Operate shift and rotate instructions. 
Left rotate through Carry contents of word (for RLC) or byte (for 
RLCB) register, n bits (n = 1 or 2), as follows: 



S^ 



U 



? 



S{ 



^ 



■'■ „':::ir».ct:rcti.j^ro^J9?^^^^ 



Type 



Mnemonic 



RR 
RR 
RRB 
RRB 



RRC 
RRC 
RRCB 
RRCB 



SDA 

SDAB 

SDAL 



Operand (s) 



rwd.l 
rwd,2 
rbd,1 
rbd,2 



rwd.rw 
rbd.rw 
rid.rw 



Table 6-3. A Summary of the Z8000 Instruction Set (Continued) 



rwd,1 


B3d4 


rwd,2 


B3d6 


rbd,1 


B2d4 


rbd,2 


B2d6 



Op Code 



B3dC 
BSdE 
B2dC 
B2dE 



B3dB OrOO 

B2dB OrOO 
BSdF OrOO 



Clock 
Cycles 



18/3" 
18/3" 
18/3" 



Status 



Operation Performed 



Right rotate contents of word (for RR) or byte (for RRB) register, n bits 
(n = 1 or 2), as follows: 



0-5 



s 



nA 



s 



Right rotate through Carry contents of word (for RRC) or byte (for 
RRCB) register, n bits (n = 1 or 2), as follows: 



Shi 



? 



fe^ 



? 



Shift arithnnetic the contents of a byte (for SDAB) word (for SDA) or 
long word (for SDAL) register, (rwj specifies the number of shift bit 
positions, and the direction (+ for left shift, - for right shift). shift 
is allowed; it causes no shift, but sets status, [rw] value range is -8 
to +8 for SDAB. -16 to +16 for SDA -32 to +32 for SDAL. Bits 
to 4 of [rw] are active, with bit 15 used for sign. Shifts occur as 
follows: 



^ Right 



Left 



>E] EHXIHt: 



7 6 
15 14 
31 30 



2 ' 
2 • 
2 1 

Bit Numbers 



^SDAB— 7 6 
*- SDA — 15 14 
'-SDAL— 31 30 



2 1 
2 1 
2 1 



Bit Numbers 



* Privileged instruction — can be executed only in system mode. 

" Number of clock cycles depends on the number of repetitions for n/m"; n ^minimum number of clock cycles and m = number of clock cycles added for each additional repetition 
of operation. The number of clock cycles for an instruction which repeats k times is n + (k-1)«m. 
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Si 

a. c 
« S 3 
^ • » 

<0 0> N) 











Table 6-3. 


A Summary 


Df the Z8000 Instruction Set (Continued) 


Type 


Mnemonic 


Operand (s) 


On r<>Ha 


B 


Clock 


Status 


Operation Performed 


wp 




^ 


Cycles 


H 


D 


O 


p 


s 


z 


c 




SDL 


rwd,rw 


B3d3 


OrOO 


4 


18/3" 






U 




X 


X 


X 


SDL. SDLB and SDLL are equivalent to SDA. SDAB and SDAL, 




SDLB 


rbd.rw 


B2d3 


OrOO 


4 


18/3" 






u 




X 


X 


X 


respectively, but they perform logical right shifts. Left shifts are iden- 




SDLL 


rid.rw 


B3d7 


OrOO 


4 


18/3" 






u 




X 


X 


X 


tical. Shifts may be illustrated as follows: 

Right Left 

'^ , . . a L . . . " 


-*►! I-I 1 1 Wcl IcW I!*! 11 + 






























7 6 2 10 ^SDLB^ 7 6 2 10 






























1514 2 1 —SDL— 1514 2 1 






























3130 2 10 —SDLL— 3130 2 10 




SLA 


rwd,data16 


B3d9 


yyyy 


4 


1 6/3" 






X 




X 


X 


X 


SLA. SLAB and SLAL are identical to SDA. SDAB and SDAL, respec- 




SLAB 


rbd,data16 


B2d9 


yyyy 


4 


16/3" 






X 




X 


X 


X 


tively, when these instructions are performing left shifts, except that 


1 


SLAL 


rld,data16 


B3dD 


yyyy 


4 


1 6/3" 






X 




X 


X 


X 


SLA. SLAB and SLAL specify the shift bit count immediately. 


3 
C 


SLL 


rwd,data16 


B3d1 


yyyy 


4 


16/3" 






u 




X 


X 


X 


SLL. SLLB and SLLL are identical to SDL. SDLB and SDLL, respec- 


1 


SLLB 


rbd,data16 


" B2d1 


yyyy 


4 


1 6/3" 






u 




X 


X 


X 


tively, when these instructions are performing left shifts, except that 


u 


SLLL 


rid.dataie 


B3d5 


yyyy 


4 


16/3" 






u 




X 


X 


X 


SLL, SLLB and SLLL specify the shift bit count immediately. 


S 

o 


SRA 


rwd.datalB 


B3d9 


yyyy 


4 


16/3" 











X 


X 


X 


SRA, SRAB and SRAL are identical to SDA, SDAB and SDAL, respec- 


o 


SRAB 


rbd.dataie 


B2d9 


yyyy 


4 


16/3" 











X 


X 


X 


tively, when these instructions are performing right shifts, except that 


n 


SRAL 


rid.dataie 


B3dD 


yyyy 


4 


16/3" 











X 


X 


X 


SRA, SRAB, and SRAL specify the shift bit count immediately. 


'5> 


SRL 


rwd,data16 


B3d1 


yyyy 


4 


16/3" 






u 




X 


X 


X 


SRL, SRLB. and SRLL are identical to SDL. SDLB. and SDLL, respec- 




SRLB 


rbd.dataie 


B2d1 


yyyy 


4 


16/3" 






u 




X 


X 


X 


tively, when these instructions are performing right shifts, except that 




SRLL 


rid.dataie 


B3d5 


yyyy 


4 


16/3" 






u 




X 


X 


X 


SRL, SRLB and SRLL specify the shift bit count immediately. 




TSET 


rwd 


8Dd6 




2 


7 










X 






[s] — [rwd](MSB).[rwd] — FFFF 




TSETB 


rbd 


8Cd6 




2 


7 










X 






[s] — [rbdKMSB). [rbd] — FF 
Move the most significant bit of the 1 e-bit register (for TSET) or 8-bit 
register (TSETB) to the Sign status. Then fill the register with 1 bits. 




TEST 


rwd 


8Dd4 




2 


7 










X 


X 


X 


[rwd] OR 




TESTS 


rbd 


8Cd4 




2 


7 








X 


X 


X 


X 


[rbd] OR 




TESTL 


rid 


9CdO 




2 


13 










X 


X 


X 


[rid] OR 
OR the specified register contents with 0. Set Status flags based on 
the result. Test a 32-bit register for TESTL, a 1 e-bit register for TEST 
and an 8-bit register for TESTB. 


• p 


rivileged instri 


jctlon — can be 


executed only in systen 


1 mode. 






.. N 


umber of clocl< 


cycles depends 


on thie number of repetil 


ions for n/m**; n =minimum number of c 


lock 


cycles and m = number of clock cycles added for each additional repetition 


of 


operation. Th 


e number of cio 


ck cycles 


for an instruci 


ion whicin repeats l< times is n + (l<-1). 


■n. 















Table 6-3 


A Summary 


of the Z8000 Instruction Set (Continued) 


Typo 


Mnemonic 


Operand(s) 


r 


>.. o^^A 




1 


Clock 


Status 


Operation Performed 


'-'K »*»**•«» 




> 
m 


Cycles 


H 


D 





P 


S 


z 


c 




LDCTL* 


NSPSEG.rws 


7DsE 






2 


7 
















[NSPSEGl -^ [n«s] 




LDCTL* 


rwd.NSPSEG 


7Dd6 






2 


7 
















[rwd] — [NSPSEG] 
Transfer data between a 16-blt register and tahe Z8001 normal 
Stack Pointer Segment Address register (R14N). 




LDCTL* 


NSPOFF.rws 


7DsF 






2 


7 
















[NSPOFF] — [rwsl 




LDCTL* 


rwd.NSPOFF 


7Dd7 






2 


7 
















[rwd] — [NSPOFF] 
Transfer data between a 1 6-bit register and the normal Stack Pointer 
Address register (R15N). 




POP 


rwd,@ris 


97sd 






2 


8 
















[n«d] - [[ris]], [ris] - [ris] + 2 




POP 


@rid,@ris 


17sd 






2 


12 
















([rid]] - [[ris]], [ris] *- [ris] + 2 




POP 


adrsx,@ris 


57si 


PPPP 


qqqq 


4/6 


15-19 
















[adrsx] «- [[ris]], [ris] «- [ris] + 2 
Pop the memory word addressed by ris, the designated Stack Pointer. 
Any register with the exception of RO (for nonsegmented) or RRO (for 
segmented) can be designated as the Stack Pointer. The popped word 
is loaded into a 1 6-bit register, or the memory location addressed by 
adrsx or [rid]. 




POPL 


rld,@ris 


95id 






2 


12 
















[rid] — [[ris]], [ris] — [ris] + 4 


o 

(0 


POPL 


@rid,@ris 


15id 






2 


19 
















[[rid]] - [[ris]], [ris] - [ris] + 4 


POPL 


adrsx,@ris 


55si 


PPPP 


qqqq 


4/6 


22-26 
















[adrsx] - [[ris]], [ris] - [ris] + 4 
































POPL is identical to POP, except that a 32-bit long word is popped. 




PUSH 


@rid,rws 


93is 






2 


9 
















[rid] — [rid] - 2.[[rid]] — [rws] 




PUSH 


@rid,@ris 


13is 






2 


13 
















[rid] - [rid] - 2. [[rid]] - [[ris]] 




PUSH 


@rid,adrsx 


53di 


PPPP 


qqqq 


4/6 


13-17 
















[rid] ^ [rid] - 2. [[rid]] ^ [adrsx] 




PUSH 


@rid,data16 


ODdS 


yyyy 




4 


12 
















[rid] «- [rid] - 2. [[rid]] — datal 6 
Push a 1 6-bit word onto a memory stack addressed by rid, the desig- 
nated Stack Pointer. Any register with the exception of RO (for non- 
segmented) or RRO (for segmented) can be designated as the Stack 
Pointer. The pushed word can come from a register, the memory 
word addressed by adrsx or [ris], or it may be immediate data. 




PUSHL 


@rid,rls 


91 is 






2 


12 
















[rid] — [rid] - 4. [[rid]] — [ris] 




PUSHL 


@rid,@ris 


11 is 






2 


20 
















[rid] - [rid] - 4. [[rid]] - [[ris]] 




PUSHL 


@rid,adrsx 


51di 


PPPP 


qqqq 


4/6 


20-24 
















[rid] '- [rid] - 4. [[rid]] — [adrsx] 
PUSHL is identical to PUSH except that a 32-bit long word is pushed, 
also there is no immediate version of PUSHL. 


• Privileged ins 


truction — can b 


e executed only 


in system m 


ode. 


*• Number of do 


ck cycles depenc 


Is on the number of repetition 


s for n/m**; n =mlnimum number of clock cycles and m = number of clock cycles added for each additional repeti tion 


of operation. ' 


rhe number of c 


ock eye 


es for an instruction which repeats k times is n + (k-1)*m. 1 



Table 6-3. A Summary of the Z8000 Instruction Set (Continued) 















S 


Clock 


Status 




Type 


Mnemonic 


Operand(s) 


( 


3p Code 




>■ 

m 


Cycles 




Operation Performed 


H 


D 





P 


S 


z 


c 




BIT 


rwd,b16 


A7db 






2 


4 












X 




Z — NOT bit b1 6 of [rwd] 




BIT 


@rid,b16 


27ib 






2 


8 












X 




Z'-NOTbit b16of [[rid]] 




BIT 


adrsx,b16 


671b 


PPPP 


qqqq 


4/6 


10-14 












X 




Z^NOTbltb16of [adrsx] 




BIT 


rwd.rws 


270s 


OdOO 




4 


10 












X 




Z ^ NOT bit [n«s] of [rwd] 
Set the Z status to the complement of the specified bit. which may be 
in a 16-bit register or memory word. The bit may be specified im- 
mediately, or for a register it may be specified by the low-order four 
bits of a 1 6-bit register. 




BITB 


rbd.bS 


A6db 






2 


4 












X 




Z ^ NOT bit b8 of [rbd] 




BITB 


@rid,b8 


26ib 






2 


8 












X 




Z — NOT bit b8 of [[rid]] 




BITB 


adrsx.bS 


661b 


PPPP 


qqqq 


4/6 


10-14 












X 




Z — NOT bit b8 of [adrsx] 




BITB 


rbd,rws 


260s 


OdOO 




4 


10 












X 




Z ^ NOT bit [rwsl of [rbd] 
Set the Z status to the complement of the specified bit, which may be 
in an 8-bit register or memory byte. The bit may be specified im- 


S 






























mediately, or for a register it may be specified by the low-order three 


e 
o 






























bits of one of the registers RO - R7. 


2 


RES 


rwd,b16 


A3db 






2 


4 
















Bitb16 of [rwd]^0 


& 


RES 


@rid,b1 6 


23ib 






2 


11 
















Bitb16of [[rid]]— 


o 


RES 


adrsx,b1 6 


63ib 


PPPP 


qqqq 


4/6 


13-17 
















Bit b16 of [adrsx] «-0 


S 


RES 

RESB 
RESB 


rwd.rws 

rbd.bS 
©rid.bS 


230s 

A2db 
22ib 


OdOO 




4 

2 
2 


10 

4 
11 
















Bit [rws] of [rwd]«-0 
Clear the specified bit. which may be in a 1 6-bit register or memory 
word. The bit may be specified immediately, or for a register it may 
be specified by the low-order four bits of a 1 6-bit register. 

Bit b8 of [rbd] — 

Bit b8 of [[rid]] — 




RESB 


adrsx.bS 


621b 


PPPP 


qqqq 


4/6 


13-17 
















Bit b8 of [adrsx] <— 




RESB 


rbd.rws 


220s 


OdOO 




4 


10 
















Bit [rws] of [rbd] — 
Clear the specified bit. which may be In an 8-bit register or memory 
byte. The bit may be specified Immediately, or for a register it may be 
specified by the low-order three bits of one of the registers RO - R7. 


• F 


rivileged instr 


jction — can be 


executed only in 


system mode. 1 


" U 


umber of clocl' 


( cycles depends 


on the number of repetitions for n/m"; n =minimum number of clock cycles and m = number of clock cycles added for each additional repetition | 


c 


f operation. T 


^e number of cic 


>ck cycles for an 


instruction which repeats k times is n + (k-l).m. 1 



Table 6-3. A Summary of the Z8000 Instruction Set (Continued) 



Type 


Mnemonic 


Operand (s) 


Op Code 


M 
i 

CD 


Clock 
Cycles 


Status 


Operation Performed 


H 


D 





p 


s 


z 


c 


1 

3 

e 
■^ 
c 
o 
O 

i 

a 
o 

ia 


SET 

SET 

SET 

SET 

SETB 

SETB 

SETB 

SETB 


rwd,b16 
@rid,b16 
adrsx,b16 
rwd,rws 
rbd.bS 
@rid,b8 
adrsx.bS 
rbd.rws 


A5db 

25ib 

65 ib pppp qqqq 

250s OdOO 

A4db 

24ib 

64ib pppp qqqq 

240s OdOO 


2 
2 

4/6 
4 
2 
2 

4/6 
4 


4 

11 
13-17 

10 

4 

11 
13-17 

10 
















Bit b1 6 of [rwd]<-1 

BitblBof [[rid]] — 1 

Bit b1 6 of [adrsx] — 1 

Bit [rws] of [rwd] — 1 

Bit b8 of [rbd] 

Bit b8 of [[rid]] 

Bit bS of [adrsx] 

Bit [ro/s] of [rbd] 
SET and SETB instructions are equivalent to RES and RESB instruc- 
tions, respectively, except that the selected bit is set. 


B 


Dl* 
El* 
IRET* 

LDCTL* 
LDCTL* 

LDCTL* 
LDCTL" 


int 
int 

PSAPSEG.rws 
rwd.PSAPSEG 

PSAPOFF.rws 
rwd.PSAPOFF 


7C OOOOOOvv 
7C 00000 Ivv 
7B00 

7DsC 
7Dd4 

7DsD 
7Dd5 


2 
2 
2 

2 
2 

2 
2 


6 

6 

13,16 

7 
7 

7 

7 


X 


X 


X 


X 


X 


X 


X 


Disable the indicated interrupt(s). Either or both of VI and NVI may be 

indicated. 

Enable the indicated interrupt(s). Either or both of VI and NVI may be 

indicated. 
[SP] — [SP] + 2. [FCW] — [[SP]]: [SP] — [SP] + 2. [PC] — [[SPj] 
[SP] — [SP] + 2. (Nonsegmented) 

[SP] - [SP] + 2. [FCW] - [[SP]]. [SP] - [SP] + 2. [PC] - [[SP]] 
[SP] — [SP] + 4. (Segmented) 

Return from interrupt. Pop and discard identifier word. Pop flag and 

control word. Pop Program Counter. 
[PSAPSEG] — [n«/s] 
[n«d] — [PSAPSEG] 

These two instructions transfer data between the Z8001 Program 

Status Area Pointer Segment register, and a 1 6-bit general purpose 

register. 
[PSAPOFF] — [rws) 
[n«d] — [PSAPOFF] 

These two instructions transfer data between the Program Status 

Area Pointer and a 1 6-bit general purpose register. 


• Privileged instruction — can be executed only in system mode. 
** Number of clock cycles depends on the number of repetitions for n/m"; n =minimum number of clock cycles and m = number of clock cycles added for each additional repetition 
of operation. The number of clock cycles for an instruction which repeats k times is n + (k-1)«m. 



Table 6-3. A Summary of the Z8000 Instruction Set (Continued) 



Type 


Mnemonic 


Operand(s) 


Op Code 


s 


Clock 


Status 


Operation Performed 


> 


Cycles 
























CO 


H 


D 


o 


p 


s 


z 


c 






COMFLG 


flag 


8Df5 


2 


7 






X 


X 


X 


X 


X 


Complement each status named in the operand. Any or all of C, Z, S, 
P, or may be named in any order. 




LDCTL* 


FCW.nws 


7DsA 


2 


7 


X 


X 


X 


X 


X 


X 


X 


[FCW] - [n«s] 
Load register contents into FCW. Unassigned bits of FCW are not 
affected. 




LDCTL* 


rwd.FCW 


7Dd2 


2 


7 
















[rwd] ^ [FCW] 
Load FCW contents into selected register. Unassigned bits of FCW 
are reset to in rwd. 




LDCTLB 


FLAGS.rbs 


8Cs9 


2 


7 


X 


X 


X 


X 


X 


X 


X 


[FLAGS] — [rbs] 
Load byte register contents into low-order byte of FCW. Bits and 1 , 
which are unassigned, are not affected. 




LDCTLB 


rbd.FLAGS 


8Cd1 


2 


7 
















[rbd] *- [FLAGS] 
Load the low-order byte of FCW into byte register rbd. Bits and 1 of 
rbd are reset to 0. 




RESFLG 


flag 


8Df3 


2 


7 






X 


X 


X 


X 


X 


Reset to each status named in the operand. 


w 


SETFLG 


flag 


8Df1 


2 


7 






X 


X 


X 


X 


X 


Set to 1 each status named in the operand. 


1 


TCC 


cc,rwd 


AFdc 


2 


5 
















If cc is "true" then set bit of Register rwd. Otherwise reset bit of 




TCCB 


ccrbd 


AEdc 


2 


5 
















Register rwd. 

If cc is "true" then set bit of Register rbd. Otherwise reset bit of 
Register rbd. 


* Privileged instr 


jction — can be 


executed only in syster 


n mo 


de. 




" Number of clocli 


^ cycles depends 


on the number of repeti 


tions 


for n/m**; n =minimum number of clock cycl 


es and m = number of clock cycles added for each additional repetition 


of operation. T 


ie number of do 


ck cycles for an instruc 


tion 


which repeats k times Is n + (k-l)'m. 













Table 6-3. A Summary of the Z8000 Instruction Set (Continued) 


Type 


Mnemonic 


Operand (s) 


Op Code 




1 


Clock 


Status 


Operation Performed 


























n 


Cycles 


H 


D 





P 


S 


z 


c 






HALT 




7A00 




2 


8/3" 
















Halt CPU until reset or interrupt 




LDCTL* 


REFRESH.rws 


7DsB 




2 


7 
















[REFRESH] ^ [rws] 
Transfer the contents of the specified 16-bit register into the 
Dynamic Memory Refresh Control register. 




LDCTL' 


rwd.REFRESH 


7Dd3 




2 


7 
















[rwd] •^ [REFRESH] 
Transfer the contents of the Dynamic Memory Refresh Control 
register to the specified 1 6-bit register. 




MBIT* 




7B0A 




2 


7 










X 






[S] — Mi _ 
Set Sign status to 1 if Ml is input low (1 ). Reset Sign status to if Ml 
is input high (0). 




MREQ* 


rwd 


7BdD 




2 


12/7" 










X 


X 




[Z] — 0. If Mi = 1 then [S] ^ and [MO] ^ 0. 

If Ml = then [MO] *- 1 . Decrement [rwd] to 0. 


^ 




























If m is still then [S] ^ 0. [i\^] ^ 0. 


2 




























If Ml is now 1 then [S] — 1 . 


o 




























[Z]-1. 


o 




























Execute a multi-micro bus request, as described in accompanying 


3 





























text. 


e 


MRES* 




7B09 




2 


5 
















[MO] «- 


n 
3 




























Output MO high. 


a. 


MSET* 




7B08 




2 


5 
















[MO] — 1 






























Output MO low. 




NOP 




8D07 




2 


7 
















No operation. 


* P 


rivileged instruction — can be executed only in 


system mode. 1 


•* Number of clock cycles depends on the number of repetitions for n/m"; n =minimum number of clock cycles and m = number of clock cycles added for each additional repetition | 





f operation. The number of clock cycles for an 


instruction which repeats k times is n + (k-1 )«m. 1 



Table 6-4. Z8000 Instruction Set Object Codes 



Mnemonic 


Object Code 


Bytes 


Clock 
Cycles 


ADC 


rwd.rws 


B5sd 


2 


5 


ADCB 


rbd.rbs 


B4sd 


2 


5 


ADD 


rwd.adrsx 


41 id 
PPPP 

qqqq 


4/6 


9-13 




rwd,data16 


01 Od 

yyyy 


4 


7 




rwd.nws 


81sd 


2 


4 




twd,@ris 


Olid 


2 


7 


ADDB 


rbd.adrsx 


40id 
PPPP 
qqqq 


4/6 


9-13 




rbd.dataS 


OOOd 
yyOO 


4 


7 




rbd.rbs 


80sd 


2 


4 




rbd,@ris 


OOid 


2 


7 


ADDL 


rid.adrsx 


56id 
PPPP 
qqqq 


4/6 


15-19 




rld,data32 


160d 

yyyy 

zzzz 


6 


14 




rid.rls 


96sd 


2 


8 




rld,@rls 


16id 


2 


14 


AND 


nwd.adrsx 


47id 
PPPP 

qqqq 


4/6 


9-13 




rwd,data16 


070d 

yyyy 


4 


7 




rwd.rws 


B7sd 


2 


4 




rwd.@rls 


07id 


2 


7 


ANDB 


rbd.adrsx 


46id 
PPPP 
qqqq 


4/6 


9-13 




rbd.dataS 


060d 
yyOO 


4 


7 




rbd.rbs 


86sd 


2 


4 




rbd.@ris 


06id 


2 


7 


BIT 


adrsx.b16 


67ib 
PPPP 
qqqq 


4/6 


10-14 




rwd.bie 


A7db 


2 


4 




@rld,b16 


27ib 


2 


8 




nwd.rws 


270s 
OdOO 


4 


10 


BITB 


adrsx.bS 


66ib 
PPPP 

qqqq 


4/6 


10-14 




rbd.bS 


A6db 


2 


4 




©rid.bS 


26ib 


2 


8 




rbd.rws 


260s 
OdOO 


4 


10 


CALL 


adrsx 


5FiO 
PPPP 
qqqq 


4/6 


12-21 




@rid 


IFdO 


2 


10/15 



Mnemonic 


Object Code 


Bytes 


Clock 
Cycles 


CALR 


disp 


Dxxx 


2 


10/15 


CLR 


adrsx 


4Di8 
PPPP 
qqqq 


4/6 


11-15 




rwd 


8Dd8 


2 


7 




@rid 


ODdB 


2 


8 


CLRB 


adrsx 


4Ci8 
PPPP 

qqqq 


4/6 


11-15 




rbd 


8Cd8 


2 


7 




@rid 


0Cd8 


2 


8 


COM 


adrsx 


4DiO 
PPPP 
qqqq 


4/6 


15-19 




rwd 


8DdO 


2 


7 




@rid 


ODdO 


2 


12 


COMB 


adrsx 


4CiO 
PPPP 

qqqq 


4/6 


15-19 




rbd 


8CdO 


2 


7 




@rid 


OCdO 


2 


12 


COMFLG 


flag 


8Df5 


2 


7 


CP 


adrsx.data16 


4Di1 

yyyy 
PPPP 

qqqq 


6/8 


14-18 




rwd.adrsx 


4Bid 
PPPP 
qqqq 


4/6 


9-13 




rwd.datalB 


OBOd 

yyyy 


4 


7 




rwd.rws 


8Bsd 


2 


4 




rwd,@ris 


OBid 


2 


7 




@rid.data16 


ODdl 

yyyy 


4 


11 


CPB 


adrsx.dataB 


4Ci1 
yyOO 
PPPP 

qqqq 


6/8 


14-18 




rbd.adrsx 


4Aid 
PPPP 
qqqq 


4/6 


9-13 




rbd.dataB 


OAOd 
yyOO 


4 


7 




rbd.rbs 


BAsd 


2 


4 




rbd.@ris 


OAid 


2 


7 




@rid.data8 


OCdl 
yyOO 


4 


11 


CPL 


rid.adrsx 


50id 
PPPP 
qqqq 


4/6 


15-19 




rld.data32 


lOOd 

yyyy 
zzzz 


6 


14 




rld.rls 


90sd 


2 


8 




rid.@ris 


lOid 


2 


14 



6-75 



Table 6-4. Z8000 Instruction Set Object Codes (Continued) 











Clock 












Clock 


Mnemonic 


Object Code 


Bytes 


Cycles 




Mnemonic 


Object Code 


Bytes 


Cycles 


CPD 


rwd,@ris,rw,cc 


BBsB 


4 


20 


DIVL 


rqd.adrsx 


5Aid 


4/6 


note 1 






Ordc 












PPPP 






CPDB 


rbd,@rls,rw,cc 


BAsB 
Ordc 


4 


20 






rqd,data32 


qqqq 
lAOd 


6 


note 1 


CPDR 


rwd,@ris,rw,cc 


BBsC 
Ordc 


4 


20/9" 








yyyy 
zzzz 






CPDRB 


rbd,@ris,rw,cc 


BAsC 
Ordc 


4 


20/9" 






rqd.rJs 
rqd,@ris 


SAsd 
lAid 


2 

2 


note 1 
note 1 


CPI 


rwd,@ris,rw,cc 


BBsO 


4 


20 




DJNZ 


rw.disp 


Fr Ottttttt 


2 


11 






Ordc 








DBJNZ 


rb.disp 


Fr Ittttttt 


2 


11 


CPIB 


rbd,@ris,rw,cc 


BAsO 


4 


20 




•El 


int 


70 000001 w 


2 


6 






Ordc 








EX 


rwd.adrsx 


6Did 


4/6 


15-19 


CPIR 


rwd,@ris,rw,cc 


BBs4 
Ordc 


4 


20/9" 








PPPP 
qqqq 






CPIRB 


rbd,@ris,rw,cc 


BAs4 
Ordc 


4 


20/9" 






rwd.rws 
rwd,@ris 


ADsd 
2Dsd 


2 

2 


6 
12 


CPSD 


@rid,@ris,rw,cc 


BBsA 
Ordc 


4 


25 




EXB 


rbd,adrsx 


eCid 
PPPP 


4/6 


15-19 


CPSDB 


@rid,@ris,rw,cc 


BAsA 
Ordc 


4 


25 






rbd.rbs 


qqqq 

ACsd 


2 


6 


CPSDR 


@rid,@ris,rw,cc 


BBsE 


4 


25/14" 






rbd,@ris 


2Csd 


2 


12 






Ordc 








EXTS 


rid 


BIdA 


2 


11 


CPSDRB 


@rid,@ris,rw,cc 


BAsE 


4 


25/14" 




EXTSB 


rwd 


BIdO 


2 


11 






Ordc 








EXTSL 


rqd 


B1d7 


2 


11 


CPSI 


@rid,@ris,rw,cc 


BBs2 


4 


25 




•HALT 




7A00 


2 


8/3^^ 






Ordc 








•IN 


rwd,ioaddr 


3Bd4 


4 


12 


CPSIB 


@rid,@ris,rw,cc 


BAs2 
Ordc 


4 


25 






rwd,@rw 


PPPP 
3Dsd 


2 


10 


CPSIR 


@rid,@ris,rw,cc 


BBs6 
Ordc 


4 


25/14" 




•INB 


rbd.ioaddr 


3Ad4 
PPPP 


4 


12 


CPSIRB 


@rid,@ris,rw,cc 


BAs6 


4 


25/14" 






rbd,@rw 


3Csd 


2 


10 






Ordc 








INC 


adrsx,n16 


69in 


4/6 


13-17 


DAB 


rbd 


BOdO 


2 


5 








PPPP 






DEC 


adrsx.n 1 6 


6Bin 
PPPP 

qqqq 


4/6 


13-17 






rwd,n 1 6 
@rid,n16 


qqqq 

A9dn 
29dn 


2 
2 


4 

1 1 




rwd,n16 


ABdn 


2 


4 




INCB 


adrsx,n16 


68in 


4/6 


13-17 




@rid,n16 


2Bdn 


2 


11 








PPPP 






DECB 


adrsx,n16 


6Ain 
PPPP 
qqqq 


4/6 


13-17 






rbd,n16 
@rid,n16 


qqqq 

ABdn 
28dn 


2 
2 


4 

11 




rbd.nie 


AAdn 


2 


4 




•IND 


@rid,@ris,rw 


3Bs8 


4 


21 




@rid,n16 


2Adn 


2 


11 








OrdB 






•Dl 


int 


7C OOOOOOvv 


2 


6 




•INDB 


@rid,@rls,rw 


3As8 


4 


21 


DIV 


rid.adrsx 


5Bid 


4/6 


note 1 








OrdB 










PPPP 








•INDR 


@rid,@ris,rw 


3Bs8 


4 


21/10" 






qqqq 












OrdO 








rld,data1 6 


IBOd 
yyyy 


4 


note 1 




•INDRB 


@rid,@ris,rw 


3As8 
OrdO 


4 


21/10" 




rid.nws 


9Bsd 


2 


note 1 




•INI 


@rid,@ris,rw 


3BsO 


4 


21 




rld,@ris 


1Bid 


2 


note 1 








OrdB 






* Privileged instruction - 


- can be executed only in 


system mode. 










" Number of clock cycles 


depends on the number o 


f repetitions for n/m"; n 


= minimum numb 


er of clock cycle 


s and 




m = 


- number of clock c 


^cles added for each addil 


ional repetition of operat 


ion. 








The nunnber of clock c 


/cles for an instruction wt 


ich repeats k times is n + (k-lNm. 
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Table 6-4. Z8000 Instruction Set Object Codes (Continued) 



Mnemonic 


Object Code 


Bytes 


Clock 
Cycles 




Mnemonic 


Object Code 


Bytes 


Clock 
Cycles 


*INIB @rid,@rls,n« 


3AsO 


4 


21 


LDB 


rbd,ris(rw) 


70id 


4 


14 


*INIR @rid,@ris,rw 

•INIRB @rid,@_ris,rw 

•IRET 

JP ccadrsx 


OrdS 
3BsO 
OrdO 
3AsO 
OrdO 
7B00 
5Eic 


4 
4 

2 

4/6 


21/10" 

21/10" 

13,16 
7-11 




(Cont.) 


rbd,@ris 
rid(disp),rbs 

rid(rw),rbs 

@rid,data8 


OrOO 
20id 
32is 
xxxx 
72is 
OrOO 
0Cd5 


2 

4 

4 
4 


7 
14 

14 

11 


cc,@rid 
JR ccdisp 
LD adrsx,data16 


PPPP 

qqqq 

lEdc 
Ecxx 
4Di5 

yyyy 
PPPP 


2 
2 

6/8 


10,15/7 

6 
14-18 




LDL 


@rid,rbs 
adrsx.rls 

rld,adrsx 


yyOO 
2Eds 
5Dis 
PPPP 

qqqq 

54id 
PPPP 


2 

4/6 

4/6 


8 

14-18 

12-16 


adrsx.rws 


qqqq 
6Fis 
PPPP 


4/6 


11-15 






rld,data32 


qqqq 
140d 
yyyy 


6 


11 


rwd.adrsx 


qqqq 
61 id 
PPPP 


4/6 


9-13 






rid.rls 
rld,ris(disp) 


zzzz 
94sd 
35id 


2 

4 


5 
17 


rwd,data16 


qqqq 

210d 


4 


7 






rld,ris(rw) 


xxxx 
75id 


4 


17 


rwd,rws 
rwd,ris(disp) 


yyyy 

Alsd 
Slid 


2 

4 


3 

14 






rld,@ris 
rid(disp),rls 


OrOO 
14id 
371s 


2 

4 


11 
17 


n«d,ris(rw) 


xxxx 
71id 


4 


14 






rid(rw),rls 


xxxx 
77is 


4 


17 


n«d,@ris 
rid(dlsp),rws 


OrOO 
21id 
33is 


2 

4 


7 
14 




LDA 


@rid,rls 
rid.adrsx 


OrOO 
1Dds 
76id 


2 

4/6 


11 
13-16 


rid(rw),rws 
@nd,data16 


xxxx 
73is 
OrOO 
0Dd5 


4 
4 


14 
11 






rld,ris(disp) 


PPPP 
qqqq 
34id 
xxxx 


4 


15 


@rid,rws 


yyyy 

2Fds 


2 


8 






rld,ris(rw) 


74id 
OrOO 


4 


15 


LDB adrsx,data8 


4Ci5 


6/8 


14-18 






rwd.adrsx 


76id 


4 


12-13 




yyOO 
PPPP 










rwd,ris(disp) 


PPPP 
34id 


4 


15 


adrsx.rbs 


qqqq 

6Eis 


4/6 


11-15 






rwd,ris(rw) 


xxxx 
74id 


4 


15 


rbd.adrsx 


PPPP 
qqqq 
60id 


4/6 


9-13 




LDAR 


rld,disp 


OrOO 
340d 
xxxx 


4 


15 




PPPP 










rwd.disp 


340d 


4 


15 


rbd.dataS 

rbd.rbs 

rbd,rls(disp) 


qqqq 
Cdyy 
AOsd 
30id 
xxxx 


2 
2 

4 


5 
3 
14 








xxxx 






* Privileged instruction — can be executed only in system nnodt 
" Number of clock cycles depends on the number of repetitions i 
m = number of clock cycles added for each additional repetitic 
which repeats k times is n + (k-1)>m. 


i. 

for n/m"; n = 

}n of operati 


= minimum numbe 
an. The number of 


r of clock cycles 
clock cycles fo 


and 

an instru 


ction 
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Table 6-4. Z8000 Instruction Set Object Codes (Continued) 









Clock 












Clock 


Mnemonic 


Object Code 


Bytes 


Cycles 




Mnemonic 


Object Code 


Bytes 


Cycles 


•LDCTL FCW.rws 


7DsA 


2 


7 


LDRB 


disp,rbs 


320d 


4 


14 


NSPOFF,rws 


7DsF 


2 


7 








xxxx 






NSPSEG.rws 


7DsE 


2 


7 






rbd.disp 


300d 


4 


14 


PSAPOFF.rws 


7DsD 


2 


7 








xxxx 






PSAPSEG.rws 


7DsC 


2 


7 




LDRL 


disp.rls 


370s 


4 


17 


REFRESH.rws 


7DsB 


2 


7 








xxxx 






rwd.FCW 


7Dd2 


2 


7 






rld,disp 


350d 


4 


17 


rwd.NSPOFF 


7Dd7 


2 


7 








xxxx 






n«d,NSPSEG 


7Dd6 


2 


7 




•MBIT 




7B0A 


2 


7 


nwd.PSAPOFF 


7Dd5 


2 


7 




•MREQ 


rwd 


7BdD 


2 


12/7" 


rwd.PSAPSEG 


7Dd4 


2 


7 




•MRES 




7B09 


2 


5 


n«d,REFRESH 


7Dd3 


2 


7 




•MSET 




7B0S 


2 


5 


LDCTLB FLAGS.rbs 


8Cs9 


2 


7 




MULT 


rid.adrsx 


59id 


4/6 


note 2 


rbs.FLAGS 


8Cd1 


2 


7 








PPPP 






LDD @rid,@ris,rw 


BBs9 


4 


20 








qqqq 








OrdS 










rld,data16 


190d 


4 


note 2 


LDDB @rid,@ris,rw 


BAs9 


4 


20 








yyyy 








OrdS 










rid.rws 


99sd 


2 


note 2 


LDDR @rid,@ris,rw 


BBs9 


4 


20/9" 






rld,@ris 


19id 


2 


note 2 




OrdO 








MULTL 


rqd.adrsx 


58id 


4/6 


note 2 


LDDRB @rid,@ris,rw 


BAs9 
OrdO 


4 


20/9" 








PPPP 

qqqq 






LDI @rid,@ris,rw 


BBsl 
OrdS 


4 


20 






rqd,data32 


ISOd 
yyyy 


6 


note 2 


LDIB @rid,@ris,rw 


BAs1 


4 


20 








zzzz 








OrdS 










rqd.rls 


98sd 


2 


note 2 


LDIR @rid,@ris,rw 


BBsl 


4 


20/9" 






rqd,@ris 


ISid 


2 


note 2 




OrdO 








NEG 


adrsx 


4Di2 


4/6 


15-19 


LDIRB @rid,@ris,rw 


BAs1 
OrdO 


4 


20/9" 








PPPP 

qqqq 






LDK rwd,b16 


BDdb 


2 


5 






rwd 


8Dd2 


2 


7 


LDM adrsx,rws,n16 


5Ci9 


6/8 


17-21/3" 






©rid 


0Dd2 


2 


12 




OsOn 








NEGB 


adrsx 


4Ci2 


4/6 


15-19 




PPPP 












PPPP 








qqqq 












qqqq 






rwd,adrsx,n16 


5Ci1 


6/8 


17-21/3" 






rbd 


SCd2 


2 


7 




OdOn 










@rid 


0Cd2 


2 


12 




PPPP 








NOP 




8D07 


2 


7 




qqqq 








OR 


rwd.adrsx 


45id 


4/6 


9-13 


rwd,@ris,n16 


ICsl 
OdOn 


4 


14/3" 








PPPP 
qqqq 






@rid,rws,n16 


1Cd9 
OsOn 


4 


14/3" 






rwd.data 1 6 


050d 

yyyy 


4 


7 


*LDPS adrsx 


79i0 


4/6 


16-23 






rwd,n«s 


S5sd 


2 


4 




PPPP 










rwd,@ris 


05id 


2 


7 




qqqq 


















@ris 


39sO 


2 


12,16 














LDR disp.nws 


330s 
xxxx 


4 


14 














rwd.disp 


310d 
xxxx 


4 


14 














* Privileged instruction — 


can be executed 


only in s 


ystem mode. 








** Number of clock cycles 


depends on the n 


umber of 


repetitions for n/m"; n = 


= minimum number of clock cycles 


and 




m = number of clock cy 


Dies added for ee 


ch additic 


jnal repetition of operation. The number of clock cycles fo 


r an instr 


uction 


which repeats k times is 


i n + (k-l).m. 
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Table 6-4. Z8000 Instruction Set Object 


Codes (Continued) 






Mnemonic 


Object Code 


Bytes 


Clock 
Cycles 




Mnemonic 


Object Code 


Bytes 


Clock 
Cycles 


ORB rbd.adrsx 


44id 


4/6 


9-13 


RES 


adrsx,b16 


63ib 


4/6 


13-17 




PPPP 












PPPP 








qqqq 












qqqq 






rbd.dataS 


040d 


4 


7 






rwd,b16 


A3db 


2 


4 




yyOO 










rwd.rws 


230s 


4 


10 


rbd.rbs 


84sd 


2 


4 








OdOO 






rbd,@ris 


04id 


2 


7 






@rid,b1 6 


231b 


2 


11 


•OTDR @rid,@ris,rw 


3BsA 
OrdO 


4 


21/10" 




RESB 


adrsx.bS 


62ib 
PPPP 


4/6 


13-17 


•OTDRB @rid,@ris,rw 


3AsA 


4 


21/10" 








qqqq 








OrdO 










rbd.bB 


A2db 


2 


4 


•OTIR @rid,@ris,rw 


3Bs2 
OrdO 


4 


21/10" 






rbd.rws 


220s 
OdOO 


4 


10 


•OTIRB @rid,@ris,rw 


3As2 


4 


21/10" 






@rid,b8 


22ib 


2 


11 




OrdO 








RESFLG 


flag 


8Df3 


2 


7 


•OUT ioaddr,rws 


3Bs6 


4 


12 




RET 


cc 


9E0c 


2 


10.13/7 




PPPP 








RL 


rwd.l 


B3d8 


2 


6 


@rw,rws 


3Fds 


2 


10 






rwd,2 


B3dA 


2 


7 


*OUTB ioaddr.rbs 


3As6 


4 


12 




RLB 


rbd.l 


B2d8 


2 


6 




PPPP 










rbd,2 


B2dA 


2 


7 


@rw,rbs 


3Eds 


2 


10 




RLC 


rwd,1 


B3dO 


2 


6 


*OUTD @rid,@ris,rw 


3BsA 


4 


21 






rwd,2 


B3d2 


2 


7 




OrdB 








RLCB 


rbd,1 


B2d0 


2 


6 


•OUTDB @rid,@ris,rw 


3AsA 


4 


21 






rbd,2 


B2d2 


2 


7 




OrdS 








RLDB 


rbd.rbs 


BEsd 


2 


9 


•OUTl @rid,@ris,rw 


3Bs2 


4 


21 




RR 


rwd.l 


B3dC 


2 


6 




OrdB 










rwd,2 


B3dE 


2 


7 


•OUTIB @rid,@ris,rw 


3As2 


4 


21 




RRB 


rbd.l 


B2dC 


2 


6 




OrdS 










rbd.2 


B2dE 


2 


7 


POP adrsx,@ris 


57si 


4/6 


15-19 




RRC 


nwd.l 


B3d4 


2 


6 




PPPP 










nwd,2 


B3d6 


2 


7 




qqqq 








RRCB 


rbd.l 


B2d4 


2 


6 


rwd,@ris 


97sd 


2 


8 






rbd,2 


B2d6 


2 


7 


@rid,@ris 


17sd 


2 


12 




RRDB 


rbd.rbs 


BCsd 


2 


9 


POPL adrsx,@ris 


55si 


4/6 


22-26 




SBC 


rwd.rws 


B7sd 


2 


5 




PPPP 








SBCB 


rbd.rbs 


B6sd 


2 


5 




qqqq 








SC 


dataS 


7Fyy 


2 


33.39 


rld,@ris 


95id 


2 


12 




SDA 


rwd.rw 


B3dB 


4 


18/3" 


@rid,@ris 


15id 


2 


19 








OrOO 






PUSH @rid,adrsx 


53di 
PPPP 


4/6 


13-7 




SDAB 


rbd.rw 


B2dB 
OrOO 


4 


18/3" 




qqqq 








SDAL 


rid.rw 


B3dF 


4 


1 8/3" 


@rid,data16 


0Dd9 


4 


12 








OrOO 








yyyy 








SDL 


rwd.rw 


B3d3 


4 


18/3" 


@rid,rws 


93is 


2 


9 








OrOO 






@rid.@ris 


13is 


2 


13 




SDLB 


rbd.rw 


B2d3 


4 


18/3" 


PUSHL @rid,adrsx 


51di 


4/6 


20-24 








OrOO 








PPPP 








SDLL 


rid.rw 


B3d7 


4 


1 8/3" 




qqqq 












OrOO 






©rid.rls 


91is 


2 


12 














@rid,@ris 


His 


2 


20 














* Privileged instruction — 


can be executed only in system mode. 








" Number of clock cycles c 


Jepends on the number of repetitions for n/m"; n 


= minimunn number of clock cycles 


and 




m = number of clock eye 


les added for each additional repetition of operation. The number of clock cycles fo 


r an instri 


iction 


which repeats k times is 


n + (k-l).m. 
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Table 6-4. Z8000 Instruction Set Object Codes (Continued) 









Clock 












Clock 


Mnemonic 


Object Code 


Bytes 


Cycles 




Mnemonic 


Object Code 


Bytes 


Cycles 


SET adrsx,b16 


65ib 


4/6 


13-17 


•SOTIR 


@rid,@ris,rw 


3Bs3 


4 


21/10" 




PPPP 












OrdO 








qqqq 








•SOTIRB 


@rid,@ris,rw 


3As3 


4 


21/10" 


rwd,b16 


A5db 


2 


4 








OrdO 






rwd,rws 


2505 
OdOO 


4 


10 




•SOUT 


ioaddr.rws 


3Bs7 
PPPP 


4 


12 


@rid,b16 


25ib 


2 


11 




♦SOUTB 


ioaddr.rbs 


3 As 7 


4 


12 


SETB adrsx,b8 


64ib 


4/6 


13-17 








PPPP 








PPPP 








•SOUTD 


@rid,@ris,rw 


3BsB 


4 


21 




qqqq 












OrdS 






rbd,b8 


A4db 


2 


4 




•SOUTDB 


@rid,@ris,rw 


3AsB 


4 


21 


rbd.rws 


240s 


4 


10 








OrdS 








OdOO 








•SOUTI 


@rid,@ris,rw 


3Bs3 


4 


21 


@rid,b8 


24ib 


2 


11 








OrdS 






SETFLG flag 


8Df1 


2 


7 




•SOUTIB 


@rid,@ris,rw 


3As3 


4 


21 


*SIN rwd.ioaddr 


3Bd5 


4 


12 








OrdS 








PPPP 








SRA 


rwd,data 1 6 


B3d9 


4 


16/3" 


•SINB rbd,ioaddr 


3Ad5 


4 


12 








yyyy 








PPPP 








SRAB 


rbd,data16 


B2d9 


4 


16/3" 


*SIND @rid,@ris,rw 


3Bs9 


4 


21 








yyyy 








Ord8 








SRAL 


rld,data16 


B3dD 


4 


16/3" 


•SINDB @rld,@rls,rw 


3As9 


4 


21 








yyyy 








0rd8 








SRL 


rwd,data16 


B3d1 


4 


16/3" 


•SINDR @rid,@ris,rw 


3Bs9 


4 


21/10" 








yyyy 








OrdO 








SRLB 


rbd,data16 


B2d1 


4 


1 6/3" 


•SINDRB @rid,@ris,rw 


3As9 


4 


21/10" 








yyyy 








OrdO 








SRLL 


rld,data16 


B3d5 


4 


16/3" 


*SINI @rid,@rrs,rw 


3Bs1 


4 


21 








yyyy 








OrdS 








SUB 


rwd,adrsx 


43id 


4/6 


9-13 


•SINIB @rid,@ris,rw 


3As1 
OrdS 


4 


21 








PPPP 

qqqq 






•SINIR @rid,@ris,rw 


3Bs1 
OrdO 


4 


21/10" 






rwd,data16 


030d 

yyyy 


4 


7 


•SINIRB @rid,@ris,rw 


3As1 


4 


21/10" 






rwd.rws 


83sd 


2 


4 




OrdO 










rwd,@ris 


03id 


2 


7 


SLA rwd,data16 


B3d9 

yyyy 


4 


16/3" 




SUBB 


rbd.adrsx 


42id 
PPPP 


4/6 


9-13 


SLAB rbd,data16 


B2d9 


4 


16/3" 








qqqq 








yyyy 










rbd.dataS 


020d 


4 


7 


SLAL rld,data16 


B3dC 


4 


16/3" 








yyOO 








yyyy 










rbd,rbs 


82sd 


2 


4 


SLL rwd,data16 


B3d1 


4 


16/3" 






rbd,@ris 


02id 


2 


7 




yyyy 








SUBL 


rld,adrsx 


52id 


4/6 


15-19 


SLLB rbd,data16 


B2d1 

yyyy 


4 


16/3" 








PPPP 

qqqq 






SLLL rld,data16 


B3d5 

yyyy 


4 


1 6/3" 






rld,data32 


120d 

yyyy 


6 


14 


•SOTDR @rid,@ris,rw 


3BsB 


4 


21/10" 








zzzz 








OrdO 










rld,rls 


g2sd 


2 


8 


•SOTDRB @rid,@ris,rw 


3AsB 


4 


21/10" 






rld,@ris 


12id 


2 


14 




OrdO 








TCC 


ccrwd 


AFdc 


2 


5 


* Privileged instruction — 


can be executec 


i only in s 


ystem mode. 










** Number of clock cycles 


depends on the r 


lumber of 


repetitions for n/m"; n = 


minimum numb€ 


r of clock cycles 


> and 




m = number of clock cy 


Dies added for e< 


3ch additi 


Dnai repetition of operation. The number o 


f clock cycles fo 


r an instri 


iction 


which repeats k times i; 


> n + (k-l).m. 
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Table 6-4. Z8000 Instruction Set Object Codes (Continued) 



IVInemonic 


TCCB 


ccrbd 


TEST 


adrsx 




rwd 




@rid 


TESTB 


adrsx 




rbd 




@rid 


TESTL 


adrsx 




rid 




@rid 


TRDB 


@rid,@ris,rw 


TRDRB 


@rid,@ris,rw 


TRIB 


@rid,@ris,rw 


TRIRB 


@rid,@ris,rw 


TRTDB 


@rid,@ris,rw 



TRTDRB @rid,@ris,rw 



Object Code 



AEdc 
4Di4 
PPPP 

qqqq 

8Dd4 
0Dd4 
4Ci4 
PPPP 

qqqq 

8Cd4 
0Cd4 
5CI0 
PPPP 

qqqq 

9CdO 
ICdO 
BSdS 
OrsO 
BSdC 
OrsO 
BSdO 
OrsO 
B8d4 
OrsO 
BSdA 
OrsO 
BSdE 
OrsE 



Bytes 



2 

4/6 



2 
2 

4/6 



2 
2 

4/6 



Cloclc 
Cycles 



5 
11-15 



7 

8 

11-15 



7 

8 

16-20 



13 
13 
25 

25/14* 

25 
25/14* 

25 
25/14* 



Mnemonic 



TRTIB @rid,@ris,rw 

TRTIRB @rid,@ris,rw 
TSET adrsx 



rwd 
@rid 
TSETB adrsx 



XOR 



XORB 



rbd 
@rid 
rwd, adrsx 



rwd,data16 

rwd.rws 
rwd,@ris 
rbd, adrsx 



rbd,data8 



rbd,rbs 
rbd,@ris 



Object Code 



B8d2 
OrsO 
B8d6 
OrsE 
4Di6 
PPPP 

qqqq 

8Dd6 
0Dd6 
4Ci6 
PPPP 

qqqq 

8Cd6 
0Cd6 
49id 
PPPP 

qqqq 

090d 

yyyy 

89sd 
09id 
48id 
PPPP 

qqqq 

080d 
yyOO 
88sd 
OBid 



Bytes 



4 
4 

4/6 



2 
2 

4/6 



2 
2 

4/6 



2 
2 

4/6 



Cloclc 
Cycles 



25 

25/14*' 
14-18 



7 

11 
14-18 



7 

11 

9-13 



4 

7 

9-13 



Privileged instruction — can be executed only in system mode. 

Number of clock cycles depends on the number of repetitions for n/m**; n = minimum number of clock cycles and 

m = number of clock cycles added for each additional repetition of operation. The number of clock cycles for an instruction 

which repeats k times is n + (k-D'm. 



Note 1 



Divisor 


DIV 


DIVL 1 


Not 
Aborted 


Divisor is 
Zero 


Dividend 
Too Large 


Not 
Aborted 


Divisor 
is Zero 


Dividend 
Too Large 


adrsx 


96-100 


14-18 


26-29 


724-728 


31-35 


52-56 


All Others 


95 


13 


25 


723 


30 


51 



Note 2 



Multiplier 


MULT 


MULTL 1 


Normal 


Multiplier 
is Zero 


Normal 


Multiplier 
is Zero 


adrsx 


71-75 


19-22 


283 + 7.m-287 + 7.m 


31-35 


All Others 


70 


18 


282 + 7.m 


30 
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Table 6-5. Z8000 Object Codes 



Object Code 


Instruction 1 


OOOd yyOO 


ADDB 


rbd.dataB 


OOid 


ADDB 


rbd,@ris 


OlOd yyyy 


ADO 


rwd,data16 


Olid 


ADD 


rwd,@ris 


020d yyOO 


SUBB 


rbd.dataB 


02id 


SUBB 


rbd,@ris 


030d yyyy 


SUB 


rwd,data16 


03id 


SUB 


rwd,@ris 


040d yyOO 


ORB 


rbd.dataB 


04id 


ORB 


rbd,@ris 


050d yyyy 


OR 


rwd,data16 


05id 


OR 


rwd,@ris 


060d yyOO 


ANDB 


rbd.dataB 


06id 


ANDB 


rbd,@ris 


070d yyyy 


AND 


rwd,data16 


07id 


AND 


rwd,@ris 


080d yyOO 


XORB 


rbd.dataB 


08id 


XORB 


rbd,@ris 


090d yyyy 


XOR 


rwd,data16 


09Jd 


XOR 


rwd,@ris 


OAOd yyOO 


CPB 


rbd.dataB 


OAid 


CPB 


rbd,@ris 


OBOd yyyy 


CP 


rwd,data16 


OBid 


CP 


rwd,@ris 


OCdO 


COMB 


@rid 


OCdl yyOO 


CPB 


@rid,data8 


0Cd2 


NEGB 


@rid 


0Cd4 


TESTB 


@rid 


0Cd5 yyOO 


LDB 


@rid,data8 


0Cd6 


TSETB 


@rid 


0Cd8 


CLRB 


@rid 


ODdO 


COM 


@rld 


ODdl yyyy 


CP 


@rid,data16 


0Dd2 


NEG 


@rld 


0Dd4 


TEST 


@rid 


0Dd5 yyyy 


LD 


@rid,data16 


0Dd6 


TSET 


@rid 


ODdS 


CLR 


@rid 


0Dd9 yyyy 


PUSH 


@rid,data16 


1 0Od yyyy zzzz 


CPL 


rld,data32 


10id 


CPL 


rld,@ris 


His 


PUSHL 


@rid,@ris 


1 20d yyyy zzzz 


SUBL 


rld,data32 


12id 


SUBL 


rld,@ris 


13is 


PUSH 


@rid,@ris 


1 40d yyyy zzzz 


LDL 


rld,data32 


14id 


LDL 


rld,@ris 


15id 


POPL 


@rid,@ris 


1 60d yyyy zzzz 


ADDL 


rld,data32 


16id 


ADDL 


rld,@ris 


17sd 


POP 


@rid,@ris 


180d yyyy zzzz 


MULTL 


rqd,data32 


18id 


MULTL 


rqd,@ris 


1 90d yyyy 


MULT 


rld.dataie 


19id 


MULT 


rld,@ris 


1 AOd yyyy zzzz 


DIVL 


rqd,data32 



Object Code 


Instruction 1 


1Aid 


DIVL 


rqd,@ris 


1 BOd yyyy 


DIV 


rld.dataie 


IBid 


DIV 


rld,@ris 


ICdC 


TESTL 


@rjd 


ICsl OdOn 


LDM 


rwd,@ris,n16 


1 Cd9 OsOn 


LDM 


@rid,rws,n16 


1Dds 


LDL 


@rid,rls 


lEdc 


JP 


cc,@rid 


IFdO 


CALL 


@rid 


20id 


LDB 


rbd,@ris 


210dyyyy 


LD 


rwd,data16 


21 id 


LD 


rwd,@ris 


220s OdOO 


RESB 


rbd.rws 


22ib 


RESB 


@rid,b8 


230s OdOO 


RES 


rwd.rws 


23ib 


RES 


@rid,b16 


240s OdOO 


SETB 


rbd.rws 


24ib 


SETB 


@rid,b8 


250s OdOO 


SET 


rwd.rws 


25ib 


SET 


@rid,b16 


260s OdOO 


BITB 


rbd.rws 


261b 


BITB 


@rid,b8 


270s OdOO 


BIT 


rwd,rws 


27ib 


BIT 


@rid,b16 


28dn 


INCB 


@rid,n16 


29dn 


INC 


@rid,n16 


2Adn 


DECB 


@rid,n16 


2Bdn 


DEC 


@rid,n16 


2Csd 


EXB 


rbd,@ris 


2Dsd 


EX 


rwd,@ris 


2Eds 


LDB 


@rid,rbs 


2Fds 


LD 


@rld,rws 


300d xxxx 


LDRB 


rbd,disp 


30id xxxx 


LDB 


rbd,ris(disp) 


310d xxxx 


LDR 


rwd,disp 


3 lid xxxx 


LD 


rwd,ris(disp) 


320s xxxx 


LDRB 


disp.rbs 


321s xxxx 


LDB 


rid(disp),rbs 


330s xxxx 


LDR 


disp.rws 


33is xxxx 


LD 


rid(disp),rws 


340d xxxx 


LDAR 


rid.disp 
rwd.disp 


34id xxxx 


LDA 


rld,ris(disp) 
rwd.ris(disp) 


350d xxxx 


LDRL 


rid.disp 


3 5 id xxxx 


LDL 


rld.ris(disp) 


370s xxxx 


LDRL 


disp.rls 


37is xxxx 


LDL 


rid(disp).rls 


39sO 


LDPS 


@ris 


3AsO OrdO 


INIRB 


@rid.@ris.rw 


3AsO OrdB 


INIB 


@rid.@ris,rw 


3As1 OrdO 


SINIRB 


@rid.@ris.rw 


3As1 OrdB 


SINIB 


@rid.@ris.rw 


3As2 OrdO 


OTIRB 


@rid.@ris.rw 


3As2 OrdB 


OUTIB 


@rid,@ris,rw 


3As3 OrdO 


SOTIRB 


@rid,@ris,rw 
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Table 6-5. Z8000 Object Codes (Continued) 



Object Code 


Instruction 1 


3As3 OrdS 


SOUTIB 


@rid,@rls,rw 


3Ad4 pppp 


INB 


rbd.ioaddr 


3Ad5 pppp 


SINB 


rbd.ioaddr 


3As6 pppp 


OUTB 


ioaddr.rbs 


3As7 pppp 


SOUTB 


ioaddr.rbs 


3As8 OrdO 


INDRB 


@rid,@rls,rw 


3As8 OrdS 


INDB 


@rid,@ris,rw 


3As9 OrdO 


SINDRB 


@rid,@ris,rw 


3As9 OrdS 


SINDB 


@rid,@ris,rw 


3AsA OrdO 


OTDRB 


@rld,@rls,rw 


3AsA OrdS 


OUTDB 


@rid,@ris,rw 


3AsB OrdO 


SOTDRB 


@rid,@rls,rw 


3AsB OrdS 


SOUTDB 


@rid,@ris,rw 


3BsO OrdO 


INIR 


@rld,@ris,rw 


3BsO OrdS 


INI 


@rid,@ris,rw 


3Bs1 OrdO 


SINIR 


@rid,@ris,rw 


3Bs1 OrdS 


SINI 


@rld,@ris,rw 


3Bs2 OrdO 


OTIR 


@rld,@ris,rw 


3Bs2 OrdS 


OUTI 


@rid,@rls,rw 


3Bs3 OrdO 


SOTIR 


@rid,@ris,rw 


3Bs3 OrdS 


SOUTI 


@rid,@ris,rw 


3Bd4 pppp 


IN 


rwd.ioaddr 


3Bd5 pppp 


SIN 


nwd.ipaddr 


3Bs6 pppp 


OUT 


ioaddr.rws 


3Bs7 pppp 


SOUT 


ioaddr.rws 


3Bs8 OrdO 


INDR 


@rid,@ris,rw 


3BsS OrdS 


IND 


@rid,@ris,rw 


3Bs9 OrdO 


SINDR 


@rid,@ris,rw 


3Bs9 OrdS 


SIND 


@rld,@rls,rw 


3BsA OrdO 


OTDR 


@rld,@ris,rw 


3BsA OrdS 


OUTD 


@rid,@ris,rw 


3BsB OrdO 


SOTDR 


@rid,@ris,rw 


3BsB OrdS 


SOUTD 


@rld,@ris,rw 


3Csd 


INB 


rbd,@nw 


3Dsd 


IN 


rwd,@rw 


3Eds 


OUTB 


@rw,rbs 


3Fds 


OUT 


@rw,rws 


40id pppp qqqq 


ADDB 


rbd.adrsx 


41 id pppp qqqq 


ADD 


rwd,adrsx 


42id pppp qqqq 


SUBB 


rbd.adrsx 


43id pppp qqqq 


SUB 


rwd.adrsx 


44id pppp qqqq 


ORB 


rbd.adrsx 


45id pppp qqqq 


OR 


rwd.adrsx 


46id pppp qqqq 


ANDB 


rbd.adrsx 


47id pppp qqqq 


AND 


rwd.adrsx 


48id pppp qqqq 


XORB 


rbd.adrsx 


49id pppp qqqq 


XOR 


rwd.adrsx 


4Aid pppp qqqq 


CPB 


rbd.adrsx 


4Bid pppp qqqq 


CP 


rwd.adrsx 


4CiO pppp qqqq 


COMB 


adrsx 


4Ci1 yyOO 


CPB 


adrsx.dataS 


pppp qqqq 






4Ci2 pppp qqqq 


NEGB 


adrsx 


4Ci4 pppp qqqq 


TESTS 


adrsx 


4Ci5 yyOO 


LDB 


adrsx.dataS 


pppp qqqq 







Object Code 


Instruction 1 


4CI6 pppp qqqq 


TSETB 


adrsx 


4CIS pppp qqqq 


CLRB 


adrsx 


4DiO pppp qqqq 


COM 


adrsx 


4Di1 yyyy 


CP 


adrsx.data16 


pppp qqqq 






4DI2 pppp qqqq 


NEG 


adrsx 


4DI4 pppp qqqq 


TEST 


adrsx 


4Di5 yyyy 


LD 


adrsx.data 1 6 


pppp qqqq 






4Di6 pppp qqqq 


TSET 


adrsx 


4Di8 pppp qqqq 


CLR 


adrsx 


50id pppp qqqq 


CPL 


rid.adrsx 


51di pppp qqqq 


PUSHL 


©rid.adrsx 


52id pppp qqqq 


SUBL 


rid.adrsx 


53di pppp qqqq 


PUSH 


©rid.adrsx 


54id pppp qqqq 


LDL 


rid.adrsx 


55si pppp qqqq 


POPL 


adrsx.@ris 


56id pppp qqqq 


ADDL 


rid.adrsx 


57si pppp qqqq 


POP 


adrsx.@rls 


58id pppp qqqq 


MULTL 


rqd.adrsx 


59id pppp qqqq 


MULT 


rid.adrsx 


5Aid pppp qqqq 


DIVL 


rqd.adrsx 


5Bid pppp qqqq 


DIV 


rid.adrsx 


5CiO pppp qqqq 


TESTL 


adrsx 


5CI1 OdOn 


LDM 


rwd.adrsx.n16 


pppp qqqq 






5Ci9 OsOn 


LDM 


adrsx.rws.n 1 6 


pppp qqqq 






5Dls pppp qqqq 


LDL 


adrsx.rls 


5Eic pppp qqqq 


JP 


cc.adrsx 


5FI0 pppp qqqq 


CALL 


adrsx 


60id pppp qqqq 


LDB 


rbd.adrsx 


Slid pppp qqqq 


LD 


rwd.adrsx 


62ib pppp qqqq 


RESB 


adrsx.bS 


63ib pppp qqqq 


RES 


adrsx.bIS 


641b pppp qqqq 


SETS 


adrsx.bS 


65ib pppp qqqq 


SET 


adrsx.b16 


66ib pppp qqqq 


BITS 


adrsx.bS 


67ib pppp qqqq 


BIT 


adrsx.bl 6 


6Sin pppp qqqq 


INCB 


adrsx.n16 


69in pppp qqqq 


INC 


adrsx.n16 


6Aln pppp qqqq 


DECS 


adrsx.n16 


6Bin pppp qqqq 


DEC 


adrsx,n16 


6Cid pppp qqqq 


EXB 


rbd.adrsx 


6Did pppp qqqq 


EX 


nwd.adrsx 


6Eis pppp qqqq 


LDB 


adrsx.rbs 


6Fls pppp qqqq 


LD 


adrsx.nvs 


70id OrOO 


LDB 


rbd.ris(rw) 


71idOrOO 


LD 


rwd.ris(rw) 


72is OrOO 


LDB 


rid(rw).rbs 


731s OrOO 


LD 


rid(rw).rws 


74id OrOO 


LDA 


rld,ris{rw) 
rwd,ris(rw) 


7 5 id OrOO 


LDL 


rld.ris(nw) 


7 6 id pppp qqqq 


LDA 


rid.adrsx 
rwd.adrsx 
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Table 6-5. Z8000 Object Codes (Continued) 



Object Code 


instruction 1 


77is OrOO 


LDL 


rid{rw),rls 


79iO pppp qqqq 


LDPS 


adrsx 


7A00 


HALT 




7B00 


IRET 




7B08 


MSET 




7B09 


MRES 




7B0A 


MBIT 




7BdD 


MREQ 


rwd 


7C OOOOOOvv 


Dl 


int 


7C 00000 Ivv 


El 


int 


7Dd2 


LDCTL 


rwd.FCW 


7Dd3 


LDCTL 


rwd,REFRESH 


7Dd4 


LDCTL 


rwd.PSAPSEG 


7Dd5 


LDCTL 


rwd.PSAPOFF 


7Dd6 


LDCTL 


rwd.NSPSEG 


7Dd7 


LDCTL 


rwd.NSPOFF 


7DsA 


LDCTL 


FCW.rws 


7DsB 


LDCTL 


REFRESH,rws 


7DsC 


LDCTL 


PSAPSEG.rws 


7DsD 


LDCTL 


PSAPOFF.rws 


7DsE 


LDCTL 


NSPSEG,rws 


7DsF 


LDCTL 


NSPOFF,rws 


7Fyy 


SC 


dataS 


80sd 


ADDS 


rbd.rbs 


81 sd 


ADD 


rwd.rws 


82sd 


SUBB 


rbd.rbs 


83sd 


SUB 


rwd.rws 


84sd 


ORB 


rbd.rbs 


85sd 


OR 


rwd.rws 


86sd 


ANDB 


rbd.rbs 


87sd 


AND 


rwd.rws 


88sd 


XORB 


rbd.rbs 


89sd 


XOR 


rwd.rws 


8Asd 


CPB 


rbd.rbs 


8Bsd 


CP 


rwd.rws 


8CdO 


COMB 


rbd 


8Cd1 


LDCTLB 


rbd.FLAGS 


8Cd2 


NEGB 


rbd 


8Cd4 


TESTB 


rbd 


8Cd6 


TSETB 


rbd 


8Cd8 


CLRB 


rbd 


8Cs9 


LDCTLB 


FLAGS.rbs 


8D07 


NOP 




8DdO 


COM 


rwd 


8Df1 


SETFLG 


flag 


8Dd2 


NEG 


rwd 


8Df3 


RESFLG 


flag 


8Dd4 


TEST 


rwd 


8Df5 


COMFLG 


flag 


8Dd6 


TSET 


rwd 


8Dd8 


CLR 


rwd 


90sd 


CPL 


rid.rls 


giis 


PUSHL 


@rld.rls 


92sd 


SUBL 


rid.rls 


93is 


PUSH 


@rld.rws 


g4sd 


LDL 


rid.rls 


95id 


POPL 


rld.@ris 



Object Code 


Instruction 


96sd 


ADDL rid.rls 


97sd 


POP rwd.@rls 


98sd 


MULTL rqd.rls 


99sd 


MULT rid.rws 


9Asd 


DIVL rqd.rls 


9Bsd 


DIV rid.rws 


9CdO 


TESTL rid 


9E0c 


RET cc 


AOsd 


LDB rbd.rbs 


Alsd 


LD rwd.rws 


A2db 


RESB rbd.bB 


A3db 


RES rwd.bie 


A4db 


SETB rwd.bS 


A5db 


SET rwd.bie 


A6db 


BITB rbd.bS 


A7db 


BIT rwd.bie 


A8dn 


INCB rbd.nie 


A9dn 


INC rwd.nie 


AAdn 


DECB rbd.nie 


ABdn 


DEC rwd.nie 


ACsd 


EXB rbd.rbs 


ADsd 


EX rwd.rws 


AEdc 


TCCB cc.rbd 


AFdc 


TCC cc.rwd 


BOdO 


DAB rbd 


BIdO 


EXTSB rwd 


B1d7 


EXTSL rqd 


BIdA 


EXTS rid 


B2dO 


RLCB rbd.l 


B2d1 yyyy 


SLLB rbd.dataie 


B2d1 yyyy 


SRLB rbd.dataie 


B2d2 


RLCB rbd.2 


B2d3 OrOO 


SDLB rbd.rw 


B2d4 


RRCB rbd.l 


B2d6 


RRCB rbd.2 


B2d8 


RLB rbd.l 


B2d9 yyyy 


SLAB rbd.dataie 


B2d9 yyyy 


SRAB rbd.dataie 


B2dA 


RLB rbd.2 


B2dB OrOO 


SDAB rbd.rw 


B2dC 


RRB rbd.l 


B2dE 


RRB rbd.2 


B3d0 


RLC rwd.1 


B3d1 yyyy 


SLL rwd.dataie 


B3d1 yyyy 


SRL rwd^dataie 


B3d2 


RLC rwdr2 


B3d3 OrOO 


SDL rwd.rw 


B3d4 


RRC rwd.1 


B3d5 yyyy 


SLLL rld.dataie 


B3d5 yyyy 


SRLL rld.dataie 


B3d6 


RRC rwd.2 


B3d7 OrOO 


SDLL rid.rw 


B3d8 


RL rwd.1 


B3d9 yyyy 


SLA rwd.dataie 


B3d9 yyyy 


SRA rwd.dataie 


B3dA 


RL rwd.2 


B3dB OrOO 


SDA rwd.rw 



6-84 



Table 6-5. Z8000 Object Codes (Continued) 



Object Code 


Instruction 


B3dC 


RR 


n«d,1 


B3dD yyyy 


SLAL 


rld,data16 


B3dD yyyy 


SRAL 


rld,data16 


B3dE 


RR 


rwd,2 


B3dF OrOO 


SDAL 


rid.rw 


B4sd 


ADCB 


rbd.rbs 


B5sd 


ADC 


rwd.rws 


B6sd 


SBCB 


rbd,rbs 


B7sd 


SBC 


rwd.rws 


BBdO OrsO 


TRIB 


@rd,@ris,rw 


B8d2 OrsO 


TRTIB 


@rid,@ris,rw 


B8d4 OrsO 


TRIRB 


@rid,@ris,rw 


B8d6 OrsE 


TRTIRB 


@rid,@ris,rw 


B8d8 OrsO 


TRDB 


@rid,@ris,rw 


BBdA OrsO 


TRTDB 


@rid,@ris,rw 


B8dC OrsO 


TRDRB 


@rid,@ris,n« 


B8dE OrsE 


TRTDRB 


@rid,@ris,rw 


BAsO Ordc 


CPIB 


rbd,@ris,rw,cc 


BAs1 OrdO 


LDIRB 


@rid,@ris,rw 


BAsI 0rd8 


LDIB 


@rid,@ris,nw 


BAs2 Ordc 


CPSIB 


@rid,@ris,rw,cc 


BAs4 Ordc 


CPIRB 


rbd,@ris,rw,cc 


BAs6 Ordc 


CPSIRB 


@rid,@ris,rw,cc 


BAs8 Ordc 


CPDB 


rbd,@ris,rw,cc 


BAs9 OrdO 


LDDRB 


@rid,@ris,rw 



Object Code 


Instruction 1 


BAs9 OrdS 


LDDB 


@rid,@ris,rw 


BAsA Ordc 


CPSDB 


@rid,@ris,rw,cc 


BAsC Ordc 


CPDRB 


rbd,@ris,rw,cc 


BAsE Ordc 


CPSDRB 


@rid,@ris,rw,cc 


BBsO Ordc 


CPI 


rwd,@ris,rw,cc 


BBs1 OrdO 


LDIR 


@rid,@ris,rw 


BBs1 0rd8 


LDI 


@rid,@ris,rw 


BBs2 Ordc 


CPSI 


@rid,@ris,rw,cc 


BBs4 Ordc 


CPIR 


rwd,@ris,rw,cc 


BBs6 Ordc 


CPSIR 


@rid,@ris,rw,cc 


BBs8 Ordc 


CPD 


rwd,@ris,rw,cc 


BBs9 OrdO 


LDDR 


@rid,@ris,rw 


BBs9 OrdS 


LDD 


@rid,@ris,rw 


BBsA Ordc 


CPSD 


@rid,@ris,rw,cc 


BBsC Ordc 


CPDR 


rwd,@ris,rw,cc 


BBsE Ordc 


CPSDR 


@rid,@ris,rw,cc 


BCsd 


RRDB 


rbd,rbs 


BDdb 


LDK 


rwd,b16 


BEsd 


RLDB 


rbd.rbs 


Cdyy 


LDB 


rbd.dataB 


Dxxx 


CALR 


disp 


Ecxx 


JR 


ccdisp 


Fr Ottttttt 


DBJNZ 


rb.disp 


Fr Ittttttt 


DJNZ 


rw.disp 
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DATA SHEETS 

This section contains specific electrical and timing data for the following devices: 

. Z8001 CPU 
. Z8002 CPU 



6-D1 



Z8001, Z8002 



Composite 
AC Timing 
Diagram 




/^^^^^^_^^V.^ 




This composite timing dia- 
gram does not show actual 
timing sequences. Refer to 
this diagram only for the 
detailed timing relationships 
of individual edges. Use the 
preceding illustrations as an 
explanation of the various 
timing sequences. 



Timing measurements are 
made at the following 
voltages 

High Low 



Clock 
Output 
Input 
Float 



4 0V 0.8V 

2.0V Q8V 

2.0V 0.8V 

AV ±0.5V 



^3- 



K!>t 



MORMAUSY STEM. 
BYTE/WORD 



Data sheets on pages 21-D2 through 21-D4 are reprinted by pernnission of Zilog, Incorporated. 



6-D2 



Z8001, Z8002 



AC Number 


Symbol 


Poorameter 


Min 


Max 


Unit 


Electrical i 


TcC 


Clock Cycle Time 


250 


2000 


ns 


Characteristics 2 


TwCh 


Clock Width (High) 


105 


2000 


ns 


3 


TwCl 


Clock Width (Low) 


105 


2000 


ns 


4 


TfC 


Clock Fall Time 




20 


ns 


n 


T C 


- Clock Rise Time 

Clock t to Segment Number Valid (50 pF load) 




20 — 

130 






6 


TdC(SNv) 




ns 
ns 


7 


TdC(SNn) 


Clock f to Segment Number Not Valid 


20 




ns 


8 


TdC(Bz) 


Clock t to Bus Float 




65 


ns 


9 


TdC(A) 


Clock t to Address Valid 




100 


ns 


— 10 — 


T ^^'( fl -i\ 


- Clock t to Address Float 




65 — 


ns 


l<j\^\i\Z) 


11 


TdA(DI) 


Address Valid to Data In Required Valid 


400 




ns 


12 


TsDI(C) 


Data In to Clock 1 Setup^ Time 


70 




ns 


13 


TdDS(A) 


DS t to Address Active ' 


80 




ns 


14 


TdC(DO) 


Clock t to Data Out Valid 




100 


ns 


1 ■=■ 


Ti-,nT('n<^i 


- Data In to DS t Hold Time 

Data Out Valid to DS t Delay 


— 

230 






ID 

16 


TdDO(DS) 




ns 

ns 


17 


TdA(MR) 


Address Valid to MREQ I Delay 


55 




ns 


18 


TdC(MR) 


Clock 1 to MREQ I Delay 




80 


ns 


19 


TwMRh 


MREQ Width (High) 


190 




ns 


— 20 


T TKjfn/ fl\ 


- MREQ I to Address Not Active 


70 — 




ns 


iu,JVirH,A; 


21 


TdDO(DSW) 


Data Out Valid to DS i (Write) Delay 


55 




ns 


22 


TdMR(DI) 


MREQ i to Data In Required Valid 


330 




ns 


23 


TdC(MR) 


Clock 1 to MREQ t Delay 




80 


ns 


24 


TdC(ASf) 


Clock t to AS t D_elay 




80 


ns 


OC 


Ti^ A( 1\^\ 


n J-J Tr->1;J i_ AC t ■p*^!^,. 


55 — 






26 


TdC(ASr) 


— /iaaress v aiiu to r\o \ L-'eiay 

Clock i to AS t Delay 


90 


ns 


27 


TdAS(DI) 


AS t to Data In Required Valid 


290 




ns 


28 


TdDS(AS) 


DS t to AS 1 Delay 


70 




ns 


29 

on 


TwAS 


AS Width (Low) 


80 

60 — 






ns 


oU 
31 


TdAz(DSR) 


J\o 1 to /iuuress JNot Active ueiay 
Address Float to DS (Read) I Delay 




ns 

ns 


32 


TdAS(DSR) 


AS 1 to DS (Read) I Delay 


70 




ns 


33 


TdDSR(DI) 


DS (Read) I to Data In Required Valid 


155 




ns 


34 


TdC(DSr) 


Clock I to DS t Delay 




70 


ns 


—35 


-TdDS(DO) — 


- DS t to Data Out and STATUS Not Valid 


80 — 




- — ns — — 


36 


TdA(DSR) 


Address Valid to DS (Read) I Delay 


120 




ns 


37 


TdC(DSR) 


Clock t to DS (Read) I Delay 




120 


ns 


38 


TwDSR 


DS (Read) Width (Low) 


275 




ns 


39 


TdC(DSW) 


Clock I to DS (Write) I Delay 




95 


ns 


—40 


-TwDSW 


- DS (Write) Width (Low) 


— 160 — 




ns 


41 


TdDSI(Dl) 


DS (Input) I to Data In Required Valid 


315 




ns 


42 


TdC(DSf) 


Clock 1 to DS (I/O) 1 Delay 




120 


ns 


43 


TwDS 


DS (I/O) Width (Low) 


400 




ns 


44 


TdAS(DSA) 


AS t to DS (Acknowledge) 1 Delay 


960 




ns 


— 45 — 


-TdC(DSA) — 


- Clock t to DS (Acknowledge) i Delay 




120 — 


ns 


46 


TdDSA(DI) 


DS (Ack.) 1 to Data In Required Delay 


420 




ns 


47 


TdC(S) 


Clock t to Status Valid Delay 




110 


ns 


48 


TdS(AS) 


Status Valid to AS f Delay 


40 




ns 


49 


TsR(C) 


RESET to Clock t Setup Time 


180 




ns 


— 50 


T^ T\fr^\ 


- RESET to Clock t Hold Time 


— 




ns 


inK((_) 


51 


TwNMI 


NMI Width (Low) 


100 




ns 


52 


TsNMI(C) 


NMI to Clock t Setup Time 


140 




ns 


53 


TsVI(C) 


VI , NVI to Clock t Setup Time 


110 




ns 


54 


ThVI(C) 


VI, NVI to Clock t Hold Time 







ns 


—55 


-TsSGT(C) 


- SEGT to Clock t Setup Time 


70 — 




ns 


56 


ThSGT(C) 


SEGT to Clock t Hold Time 







ns 


57 


TsMi(C) 


Ml to Clock t Setup Time 


180 




ns 


58 


ThMi(C) 


Ml to Clock t Hold Time 







ns 


59 


TdC(Mo) 


Clock t to Mo Delay 


1 /in 


120 


ns 


dO 


Isblr(C) 


oiUr to UlocK 1 betup time 


i4U 




ns 


61 


ThSTP(C) 


STOP to Clock 1 Hold Time 







ns 


62 


TsWT(C) 


WAIT to Clock 1 Setup Time 


70 




ns 


63 


ThWT(C) 


WAIT to Clock 1 Hold Time 







ns 


64 
—65 


TsBRQ(C) 
-ThBRQ(C) — 


BUSRQ to Clock t Setup Time 

FtTf^r^f^ r ^1 1 t TT 1 1 T' 


90 




ns 


cUbriU to dock I nola lime 


u 




ns 


66 


TdC(BAKr) 


Clock 1 to BUSAK t Delay 




100 


ns 


67 


TdC(BAKf) 


Clock t to BUSAK 1 Delay 




100 


ns 
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Z8001, Z8002 



Absolute Voltages on all inputs and outputs 

Maximum with respect to GND -0.3 V to +7.0 V 

Ratings Operating Ambient 

Temperature 0°Cto +70 °C 

Storage Temperature -65°Cto +I50°C 



Stresses greater than those listed under Absolute Maxi- 
mum Ratings may cause permanent damage to the device. 
This is a stress rating only; operation of the device at any 
condition above those indicated in the operational sections 
of these specifications is not implied. Exposure to absolute 
maximum rating conditions for extended periods may affect 
device reliability. 



Standard The characteristics below apply for the 

Test following standard test conditions, unless 

Conditions otherwise noted. All voltages are referenced to 
GND. Positive current flows into the refer- 
enced pin. Standard conditions are as follows: 

L +4.75 V < Vcc ^ +5.25 V 

D GND = V 

G 0°C < T„ < +70°C 



*'I 



All d. 
cept fot 
output ; 



pdramt^ters assume a load capacitance ot 100 pF max, ex- 
parameter 6 (50 pF max). Timing references between two 
ignals assume a load difference of 50 pF max. 



DC 

Character- 
istics 



Symbol 


Parameter 


Min 


Max 


Unit 


Condition 


VCH 


Clock Input High Voltage 


Vcc-0.4 


Vcc + 0.3 


V 


Driven by External Clock Generator 


VCL 


Clock Input Low Voltage 


-0.3 


0.45 


V 


Driven by External Clock Generator 


VlH 


Input High Voltage 


2,0 


Vcc + 0.3 


V 




ViL 


Input Low Voltage 


-0.3 


0.8 


V 




VOH 


Output High Voltage 


2.4 




V 


Iqh = -250 ,jA 


Vol 


Output Low Voltage 




0.4 


V 


IqL = +2.0 mA 


IlL 


Input Leakage 




±10 


/*A 


0.4 < VjN £ +2.4 V 


lOL 


Output Leakage 




±10 


^A 


0.4 < Vqut £ +2.4 V 


Ice 


Vcc Supply Current 




300 


mA 






_ „ Temperature 
Part Number r^^^^ 


Number 
of Pins 


Package 




Description 


Z8001 CPU 
Z8002 CPU 


0°C to +70°C 
0°C to +70°C 


48 
40 


Ceramic 
Ceramic 




Segmented 16-Bit Microprocessor 
Non-Segmented 16-Bit Microprocessor 



Ordering 
Information 
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Chapter 7 
THE MOTOROLA MC68000 



The MC68000 microprocessor is Motorola's first 16-bit microprocessor. It is the third of the new generation of these 
devices, having been preceded by Intel's 8086 and Zilog's Z8000. 

The MC68000 is not program compatible with Motorola's family of 8-bit microprocessors. Motorola has opted for 
designing an instruction set which provides maximum power and simplicity rather than compatibility. 

The following is a discussion of interesting MC68000 features as compared to similar capabilities of the Z8000 and 
8086: 

. 1) The MC68000 overlaps the fetching of each instruction's object code with the decoding and execution at 
the two prior instructions to obtain a pipeline effect. The Z8000 uses this approach, but only under certain 
circumstances. On the other hand, the 8086 performs extensive pipelining using a 6-byte object code 
pipeline. 

2) Both the 8086 and the Z8000 family of microprocessors provide methods of operating the devices in a "sim- 
ple" system configuration or "complex" system configuration. The 8086 accomplishes this within a single 
device by having a number of dual-function pins which serve one function in simple systems and another 
function in complex systems. The Z8000, on the other hand, is supplied in two versions: the Z8001 for com- 
plex configurations and the Z8002 for simple configurations. The MC68000 is contained in a 64-pin 
package and therefore need not attempt to accommodate different complexities of system configurations; it 
is always capable of operating in what is, effectively, a "maximum" or "complex" system configuration 
mode. 

3) The MC68000 has built-in logic to handle bus access arbitration in multi-CPU configurations. The 8086 and 
the Z8000 have equivalent logic. 

4) The MC68000 can directly access up to 1 6 million (1 6M) bytes of memory with its 24-bit Address Bus. This 
memory space may be expanded to 64M bytes by using the Function Code lines. In comparison, the 8086 
can directly address only 64K bytes of memory but can address up to one million bytes using segment 
registers. The Z8000 is also limited to 64K bytes of directly addressable memory; however, the Z8001 ver- 
sion can address as many as 48M bytes of memory using internal segment registers and external segmenta- 
tion in a memory management device. 

5) The MC68000 can be operated in either a "Supervisor" or a "User" mode. Certain privileged instructions can 
be executed in Supervisor mode only. Supervisor and User modes also have separate stack pointers. Thus, in 
program-intensive applications, systems software (executed in Supervisor mode) can be separated from 
applications programs (executed in User mode). The Z8000 series microprocessors provide similar 
capabilities. The Supervisor mode of the MC68000 is equivalent to the System mode of the Z8000, while the 
User mode of the MC68000 is equivalent to the Normal mode of theZBOOO.The 8086 offers no similar operat- 
ing modes. 

6) The MC68000 has seventeen 32-bit registers. Eight of the registers are designated as Data registers and can 
be accessed as either 8, 16, or 32-bit registers. The remaining nine registers are designated as Address 
registers, with two of these being reserved for use as the stack pointers (Supervisor and User). The Address 
registers can be accessed as 1 6 or 32-bit registers. Ail of the registers can also function as Index registers. In 
contrast, all of the Z8000 registers are 16-bit registers, although they can be paired to operate as 32-bit 
registers. The 8086 has only four 16-bit registers plus three separate 16-bit Index registers. 

7) The MC68000 provides separate pins for every data line and address output line. This is possible since the 
MC68000 is contained in a 64-pin package and as a result there is no shortage of pin connections. The 
Z8000 microprocessors and the 8086 are housed in smaller packages and therefore their data and address 
lines must share some pins. Thus the Z8000 and 8086 devices multiplex some of the data and address sig- 
nals on the same pins, and you must provide external logic to demultiplex these signals. 
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The primary source for the MC68000 is: 



MOTOROLA SEMICONDUCTOR. 
3501 Ed Bluestein Blvd. 
Austin, Texas 78721 



INC. 



The MC68000 is manufactured using N-channel HMOS process technology. The device is contained in a dual inline 64- 
pin package. A single -I-5V power supply is required and all signals are TTL-level compatible. 

The MC68000 requires an external clock which can be run at a maximum frequency of 8 MHz. The minimum instruc- 
tion execution time is four clock periods. The maximum number of clock periods for instruction execution is 158 for 
signed division and multiplication. 

THE MC68000 PROGRAMMABLE REGISTERS 

Figure 7-1 illustrates the registers provided by the IViC68000. There are seventeen 32-bit Data and Address 
registers, a 32-bit Program Counter (of which only 24 bits are used) and a 16-bit Status register. The most signifi- 
cant difference between the registers provided by the MC68000 and those of other 16-bit microprocessors is that the 
Data and Address registers are all 32 bits wide. By comparison, the 8086 and Z8000 microprocessors use 16-bit wide 
registers. 

The Data registers can be used to handle 8-bit bytes, 16-bit words, or 32-bit long words. 
The following illustration shows how the various sized operands are positioned within the 
Data registers. 



MC68000 

DATA 

REGISTERS 



31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 876543210 

M i I M M irr 



n 



n 



— Byte Operands - 
Word Operands 



Long Word Operands 



-Bit No. 

-Data Register 
(D0-D7) 



8-bit byte operands occupy bits through 7 of a Data register, while a word operand occupies bits through 15 of a 
Data register. A long word operand uses all 32 bits of a Data register. When a Data register is used as a source or 
destination operand, only the appropriate low order portion of the register will be altered by the specified operation; the 
more significant bits will be unaffected. For example, if you have specified an arithmetic shift left (ASL) instruction with 
an operand size of eight bits, then only the least significant eight bits (bits 0-7) of the data register will be shifted: bits 8 
through 31 will be unchanged by the instruction execution: 



31 



876543210 



I I I I I I I I I I I I I I I I I I I I I I I r 



Unchanged - 



I 



To Carry Flag 



In addition to being used as the source or destination for instructions the Data registers can also be used as index 
registers or data counters. 
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3130 29 28 27 26 252423 22 2120 19 18 17 16 15 14 13 12 1110 9 8 7 6 54321 ■^— Bit No (for all 
' I II II I II I TTI dOX ''S^t.rsl 

zz: 1 °' 

1 02 



I 



31 



16 15 



24 23 



Data 



]d3 

"1 04 / Registers 

]d5 

]d6 
]d7 



JAO 
]A, 

1a3 



A4 



] 

]a5 

]a6 



Address 
Registers 



E User Stack Pointer I » -, \ 

Supervisor Stack Pointer J ( 



Stack Pointers 



1 Prog 



ram Counter 



15 8 7 

I System Byte ) User Byte | Status Register 



Figure 7-1. MC68000 Programmable Registers 



|y/IC68000 
ADDRESS 
REGISTERS 



There are seven general purpose Address registers (A0-A6). These registers can handle 

either 16-bit word or 32-bit long word operands. When you use one of these address registers 

to provide a source operand, either the low order 1 6 bits will be used (if a word operand has been 

specified) or the entire 32 bits will be used (if a long word operand has been specified). If the 

Address register is used as the source for a word operand, then the more significant 16 bits (bits 16-31) will not be 

affected. If an Address register is used as the destination operand, however, the contents of the entire register will be 

affected, regardless of whether a word or long word operand is specified. If you specify a word destination operand for 

an Address register, that word will be automatically sign-extended to 32 bits before it is loaded into the Address 

register. 

— Bit No. 
—Data Register 
(A0-A6) 



3130 29282726 25242322 212019 1817 16 15 14 13 12 1110 9 8 7 6 5 4 3 2 1 


■ 


1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 


M M M M 1 M M 1 


1 \ 






•• ■ Long Wore 


1 Operands 


^ 
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As we have already pointed out, all of the MC68000 Data and Address registers are 32 bits wide versus the 1 6-bit wide 
registers of the Z8000 and 8086. Another significant difference between the MC68000 registers and those of the 8086 
is the general purpose nature of the MC68000 registers. This is similar to the approach taken in the Z8000 and provides 
the programnner with increased flexibility. Although there are nninor differences between the way the Data and Address 
(A0-A6) registers handle various data widths, each register type may be used in similar ways. The only dedicated 
registers are the Stack Pointer registers (A7, Supervisor and User), the Program Counter and the Status register. Let us 
now examine these dedicated registers. 



MC68000 

STACK 

POINTERS 



The MC68000 can be operated in a Supervisor (or system) mode, or in a User (or normal) 
mode. The state of the S-bit in the Status register determines the mode of operation for the 
MC68000. Supervisor mode will normally be used by operating system software; User mode will 
typically be used by application programs. A number of instructions are designated as privileged 
and can only be executed when the processor is in Supervisor mode. The Supervisor and User modes also have sep- 
arate stack pointers as mentioned earlier. As you can see in Figure 7-1, both stack pointers are addressed as 
Address register A7. When the MC68000 is operating in the Supervisor state, the User Stack Pointer cannot be 
referenced. Conversely, when the MC68000 is in the User state, the Supervisor Stack Pointer cannot be referenced. 
Both the User and Supervisor Stack Pointers operate in the same way: the system stacks are filled from high 
memory to low memory. On subroutine calls the Program Counter contents are pushed onto the appropriate system 
stack (Supervisor or User). The Program Counter contents will be pulled from the Stack and restored to the Program 
Counter on return from subroutines. Since the Program Counter is a 32-bit register, four bytes (two words) of 
memory will be required to save the contents of the Program Counter on the Stack. The organization of the Pro- 
gram Counter contents on the System Stack after a subroutine call is illustrated as follows: 
Memory 



Address 



"1 

n 
n - 2 
n - 4 



15 14 13 12 1110 9 8 7 6 5 4 3 2 10 



-Bit No. 



PC low-order word 



LSB 



MSB 



PC high-order word 



-Even Byte- 



-Odd Byte- 



Data that is pushed onto the Stack is always written to a word boundary in memory; that is, to a memory location with 
an even address. Therefore, when bytes of data must be pushed onto the stack they are written into the high-order half 
of the memory word, and the low-order half of that word (corresponding to an odd memory address) will be unchanged. 

The MC68000 addresses memory as either 8-bit bytes or as a 16-bit word comprised of two bytes. All words 
must be referenced at even address locations. Otherwise, misalignment could occur when the microprocessor 
attempts to perform a word operation at an odd-memory address. This same problem exists with any of the 16-bit 
microprocessors, but the MC68000 is the only microprocessor which automatically checks to ensure that ail word 
references are done at even memory addresses. If a word reference is made to an odd memory address, the MC68000 
begins an exception processing sequence, which will be described later. 

The following illustration shows how bytes are organized in memory: 

15 14 1 3 1 2 1 1 1 9 _8 7 6 5 4 3 2 1 ' ^— ^Bit No. 

High Memory 



Byte FFFFFE 


Byte FFFFFF 


Byte FFFFFC 


Byte FFFFFD 


Byte FFFFFA 


Byte FFFFFB 


Byte FFFFF8 


Byte FFFFF9 


Byte FFFf F6 


Byte FFFFF7 


Byte FFFFF4 


Byte FFFFF5 


1 1 


Byte 000006 


Byte 000007 


Byte 000004 


Byte 000005 


Byte 000002 


Byte 000003 


Byte 000000 


Byte 000001 



Low Memory 
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You will note that the first byte in nnemory (address 000000) occupies the most significant byte half of a nnemory word. 
When words are stored in memory, they are only addressable at even memory addresses, as we have discussed. This 
can be illustrated as follows: 



15 14 13 12 1110 9 87654321 



Word FFFFFE 



Word FFFFFC 



Word FFFFFA 



Word FFFFF8 



Word FFFFF6 



Word FFFFF4 



Word 000006 



Word 000004 



Word 000002 



Word 000000 



m Bit No. 

High Memory 



Low Memory 



When 32-bit long words (such as 32-bit addresses) are stored in memory, they occupy two adjacent 16-bit memory 
locations or four bytes. The high-order word of the long words is stored at the higher memory location, as illustrated 
below: 



15 14 13 12 1110 9 876543210 



MSB 


High-order 






Low-order 


LSB 












MSB 


High-order 






Low-order 


LSB 


MSB 


— ^ Long word or address 


LSB 



m Bit No. 

High Memory 



Low Memory 



The MC68000 provides a 16-bit Status register which is divided into two 8-bit bytes: the IVIC68000 

System byte and the User byte. Figure 7-2 shows the bit assignments for the Status STATUS 

register. The Carry. Overflow, Zero, and Negative bits are the standard ones provided by REGISTER 
most microprocessors. 

The Carry (C) bit is set if there is a carry out of the most significant bit following an addition operation, or if a 
borrow is required from the most significant bit during a subtraction. This status bit is also modified by certain shift 
and rotate instructions. 

The Overflow (V) bit is the exclusive-OR of the carries out of the most significant and next higher-order bits of 
the operand following arithmetic operations. The setting of the overflow bit signifies a magnitude overflow since the 
result cannot be represented in the specified operand size. 

The Zero (Z) bit is set whenever the result of an operation is zero; it is reset otherwise. 

The Negative (N) bit is the equivalent of the Sign status bit provided in most microprocessors. The Negative bit is 
equal to the value of the most significant result bit following arithmetic operations. If a signed binary arithmetic 
operation is being performed, a Negative status of specifies a positive or zero result, whereas a Negative status of 1 
specifies a negative result. 

The Extend (X) bit is used in multiprecision arithmetic operations. When it is affected by an instruction, it is set 
to the same state as the Carry bit. 

The three most significant bits (bits 5, 6, and 7) of the User byte of the Status register are not currently 
assigned and will always be zero. 
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System Byte 
15 14 13 12 11 10 




n M n III 



Bit No. 



■Carry 
-Overflow 
-Zero 
■Negative 



-Extend 

-Interrupt Mask 
-Supervisor/User Mode Select 
-Trace Mode 



Figure 7-2. MC68000 Status Register Bit Assignments 

The System byte of the Status register contains status information that is system-related. The User byte, on 
the other hand, contains the Condition Code status bits (X, N, Z, V, and C) that are instruction or program 
related. Bits in the System byte of the Status register can only be altered when the MC68000 is in the Super- 
visor mode. 

The three least significant bits (bits 8, 9, and 1 0) of the Status register's System byte form the interrupt mask. 

The MC68000 provides seven levels of interrupts. The level of any given interrupt is decoded from the signal's three 
interrupt pins, which we will describe later. The interrupt priorities are numbered from 1 to 7, with level 7 having 
the highest priority, as shown in the following illustration: 



Highest priority 
(Non-maskable) 



Interrupt 
Level 


Interrupt Mask 1 


•2 


'1 


'0 


Level 7 
Level 6 
Level 5 
Level 4 
Level 3 
Level 2 
Level 1 
Level 


1 
1 
1 
1 







1 

1 




1 
1 












■Lowest Priority 
■No Interrupt Request 



The level 7 interrupt is nonmaskable and thus cannot be disabled. Level represents a "no interrupt request" condition. 
Levels 1 through 6 are the mask-enabled levels. For example, if you set the mask to 1 00 then only levels 5, 6, and 7 will 
be enabled; interrupt levels 1 through 4 are disabled and interrupt requests of those levels will be ignored. 

Bit 1 3 of the Status register is the S-bit which specifies whether the MC68000 is in the Supervisor or User 
mode of operation. When this bit is 1 , the MC68000 is in the Supervisor mode, and when it is the microprocessor is 
in the User mode. Recall that the Supervisor and User modes have their own separate stack pointers; also, certain pri- 
vileged instructions can only be executed in the Supervisor mode. 

The most significant bit of the Status register is the Trace mode (T) flag. If this bit is then the MC68000 operates 
normally. If this bit is 1, however, the microprocessor is in the trace mode of operation. The trace mode is the 
approximate software equivalent of a hardware implemented single-step mode. After each instruction is executed 
in the trace mode, a trap is forced so that a debugging program can monitor the results of that instruction's execution. 
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Table .7-1. MC68000 Addressing Mode Summary 



Mode 


Address Formation 


Register Direct Addressing 
Data Register Direct 
Address Register Direct 


EA = DREGn 
EA = AREGn 


Register Indirect Addressing 
Register Indirect 
Postincrement Register Indirect 
Predecrement Register Indirect 
Register Indirect with Offset 
Indexed Register Indirect with Offset 


EA = (AREGn) 

EA = (AREGn); Increment (AREGn) 

Decrement (AREGn); EA = (AREGn) 

EA = (AREGn) + data 16 

EA = (AREGn) + (XREGn) + dataS 


Implied Register Addressing 


EA = SR, SP, PC 


Absolute Addressing 
Absolute Short 
Absolute Long 


EA = (Next word) 
EA = (Next 2 words) 


Program Counter Relative Addressing 
Relative with Offset 
Relative with Index and Offset 


EA = (PC) + data 16 

EA = (PC) + (XREG) + dataS 


Immediate Data Addressing 
Immediate 
Quick Immediate 


Data = Next word Or words 
Data inherent in instruction word 


EA = Effective Address dataS = 8-bit offset (displacement) 
DREGn = Any Data Register data 16 = 1 6-bit offset (displacement) 
AREGn = Any Address Register SR = Status Register 
XREGn = Any Data or Address Register SP = Stack Pointer (User or Supervisor) 

used as an Index Register PC = Program Counter 
( ) = Contents of 



MC68000 ADDRESSING MODE SUMMARY 

The MC68000 provides six basic types of addressing modes. Variations within these types allow a total of four- 
teen different modes, as summarized in Table 7-1. At this point, we will look only briefly at the addressing 
modes and how they utilize the registers of the MC68000. We will discuss each of the addressing modes in detail 
later, just prior to our description of the instruction set. 

Most of the addressing modes use the 32-bit Address registers either directly or indirectly to generate the effective 
address. The Data registers can be used as sources for addresses in the direct addressing mode, and they can also be 
used as Index registers in some of the indirect addressing modes. The indirect addressing modes include post-incre- 
menting or pre-decrementing of an Address register; this capability makes it easy to implement stacks and queues in 
memory. 

A number of MC68000 instructions use the implied addressing mode; that is, they make implicit reference to either the 
Program Counter (PC). Stack Pointer (SP) or Status Register (SR). For example. Branch, Jump, and Return instructions 
will all reference the Program Counter and Stack Pointer during their execution. 

Absolute addressing modes do not utilize the Data or Address registers, but instead form the effective address using 
data that follows the instruction word in the program. Program Counter relative addressing can use either a displace- 
ment or a displacement plus the contents of an Index register to form the effective address. The Index register can be 
any of the Data or Address registers. 

Most instructions can utilize any of the addressing modes, and address formation is always the same regardless of the 
instruction operation itself. These factors do much to enhance the flexibility and power of the instruction set without 
making the instruction set difficult to understand. 
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MC68000 



Pin Name 


Description 


Type 


D0-D15 


Data Bus 


Bidirectional, Tristate 


A1-A23 


Address Bus 


Output, Tristate 


AS 


Address Strobe 


Output, Tristate 


R/W 


Read/Write Control 


Output, Tristate 


UDS, LDS 


Upper, Lower Data Strobes 


Output, Tristate 


DTACK 


Data Transfer Acknowledge 


Input 


FCO, FC1, FC2 


Function Code (status) Outputs 


Output, Tristate 


IPLO, IPL1 , IPL2 


Interrupt Requests 


Input 


BERR 


Bus Error 


Input 


HALT 


Halt Processor Operation 


input/Output 


RESET 


Reset Processor or Reset External Devices 


Input/Output 


CLK 


System Clock 


Input 


BR 


Bus Request 


Input 


BG 


Bus Grant 


Output 


BGACK 


Bus Grant Acknowledge 


Input 


E 


Enable (Clock) Output 


Output 


VMA 


Valid Memory Address 


Output, Tristate 


VPA 


Valid Peripheral Address 


Input 


Vcc. GND 


Power (+5 V) and Ground 





Figure 7-3. MC68000 Pins and Signal Assignments 
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MC68000 PINS AND SIGNALS 

Figure 7-3 illustrates the signals and pin assignments for the MC68000. At this point, we will briefly discuss each 
of these signals to provide an overview of how the MC68000 operates. We will defer a detailed discussion of signal and 
timing interactions until later in this chapter. 

D0-D15 is the bidirectional 16-bit Data Bus. A1-A23 is the output 24-bit address bus. Because the MC68000 is 
contained in a 64-pin package, the data and address lines need not be multiplexed onto the same pins, as is the case 
with the 8086 and Z8000 microprocessors. Note that AO, the least significant bit of the Address Bus, is not output; 

this bit i s used internal to the MC68000, in conjunction with the data size specification of each instruction, to generate 
the UDS and LD5 signals. 

The UDS (Upper Data Strobe) and LDS (Lower Data Strobe) signals determine whether data is being transferred 
on either the upper (most significant) byte, th e lower (le ast significant) byte or both bytes of the 1 6-bit data 
bus. Table 7-2 defines the significance of the UDS, LDS, and Read/Write (R/W) signals in relation to the data 
bus. When UDS is low, data from memory with an even address is accessed and the byte of data is transferred on D8- 
D15. When LDS is low, a byte of data located at an odd address is accessed and the transfer occ urs o n D 0-D7. When 
the MC68000 is transferring a word of data (for example, when fetching an instruction) then both UDS and LDS will be 
low and all 16 of the data lines (D0-D15) will be used for the transfer. 



Table 7-2. MC68000 Data Bus Control Signal Summary 
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Table 7-3. 


MC68000 Function Code Summary 
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Figure 7-4. MC68000 Interface to Memory 



The memory interface implied by the UDS and LDS sig nals is illustrated in Figure 7-4. Byte- 
oriented nnemory with even addresses will be selected by UDS, and that memory s data lines are 
connected to D8-D15. LDS references_byte memory with odd addresses, and its data will be 
applied to D0-D7 of the Data Bus. The AS line, shown in Figure 7-4, is the Address Strobe which is 
pulsed low to indicate that a valid data address is being output on the Address Bus (A1-A23). 



MC68000 
MEMORY 
INTERFACE 



DTACK is the Data Transfer Acknowledge input signal. This signal must be asserted by external logic during 
every read or write cycle. When the MC68000 is performing a read or write cycle, it will automatically insert wait 
states in the cycle until the DTACK signal is received. This approach is thus the inverse of the logic used by most other 
microprocessors: for example, both the ZBOOO and 8086 have a "wait" input which external logic can use to extend a 
read or write cycle — if the wait input is not asserted, the read/write cycle will finish normally. The MC68000 approach 
provides for completely asynchronous bus operations that can interface to any type of device regardless of that 
device's speed . This a pproach specifies, however, that all devices in the system must include sufficient logic to 
generate the DTACK signal. 

FCO, FC1, and FC2 are the Function Code or processor cycle status outputs. These outputs identify the type of 
bus activity currently being performed by the MC68000, as summarized in Table 7-3. The Function Code outputs 
are valid whenever AS is true. Five different types of cycles are currently defined: access to either supervisor data 
memory, supervisor program memory, user data memory, or user program memory, and interrupt acknowledge 
cycles. Whenever the MC68000 is involved in fetching instructions, it is considered as accessing program memory. All 
other memory accesses are identified as data memory accesses. The Function Code outputs could be used to separate 
memory into the four different categories — user versus supervisor and program versus data. Thus, by using the FC 
outputs an MC68000 system could directly address up to 64 megabytes of memory, with 16 megabytes devoted to 
each of the four defined memory categories. 

iPLO, IPL1, and IPL2 are the interrupt request inputs. These three inputs are decoded internally by the 
MC68000 to determine the priority level of the interrupt request. You will recall from our earlier discussion of the 
Status register that there is a 3-bit interrupt mask which determines what level of interrupt request will be permitted. 
When all three interrupt inputs are low, a non-maskable interrupt (level 7, which is the highest priority) is present. This 
level is always recognized by the MC68000. When all three of the interrupt inputs are high, it indicates that no interrupt 
is being requested. 



BERR is the Bus Error input. When this signal is low the MC68000 performs a sequence (exception proc essing 
sequence) similar to that which it executes in response to an interrupt request. The pu rpose o f the BERf) signal 
is to inform the MC68000 when an external device has not responded (using the DTACK input) within an 
expected amount of time during a read or write operation. Since the data transfer handshaking approach used by 
the MC68000 requires all external devices to actively respond to every data transfer, the system should include a 
mechanism to ensure that the processor is not hung up indefinitely by a devi ce that fails to respond. Thus external logic 
should be provided to monitor bus activity and which would utilize the BERR signal to inform the MC68000 of a "failure 
to respond" condition. This logic would separate the preceding cause of a bus error from other causes, such as might 
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be generated with a Memory Management Unit (MMU). The MMU would generate BERR if an attempt was made to 
access protected memory. 

As we have already mentioned, the reaction of the MC68000 to the Bus Error input is similar to the interrupt request 
response. We will describe this response, termed "exception processing," in detail later in this chapter. Essentially, 
exception processing causes processor status information to be saved, and then allows the processor to execute a prc- 
gram t o analyze the cause of the error. The MC6800 also p rovides a hardware-oriented response to a bus error: if the 
HALT signal is asserted in conjunction with the BERR signal, the MC68000 will automatically retry the bus 
cycle that produced the error. 



The HALT signal p erform s several functions. As we mentioned in the preceding paragraph, it can be used in con- 
junction with the BERR signal to initiate rerunning of bus cycles that produced b us err ors. When used alone, it 
places the MC68000 in a Halt state where the processor is essentially inactive until the HALT signal is negated. This is 
the familiar Halt function provided by most microprocessors. 



The H ALT si gnal is also used in conjunction with the RESET signal to intialize the MC68000. One unusual aspect 
of the RESET signal is the fact that it is also an ouput signal; the MC68 000 provides a RESET instruction which, 
when executed, causes a low-going pulse to be output on the RESET pin. Thus, you can execute a RESET instruc- 
tion and use it to initialize other devices in the system without resetting the processor. 



HALT, like RESET, is an output signal. If the processor c eases executing instructions — for example, if a double 
bus fault condition occurs — the MC68000 will output HALT low. External logic can be then used to detect this 
potentially catastrophic condition. 

CLK is the single TTL-level compatible clock from which all MC68000 internal timing is derived. 

BR (Bus Request), BG (Bus Grant), and BGACK (Bus Grant Acknowledge) ar^e all bus arbitration signals. These 
signals are used in systems where other devices, such as DMA controllers on other processors, require control of the 
System Busses. External devices request access to the System Bus by asserting the BR input. The MC68000 will 
then always relinquish the bus after it has completed the current bus cycle. It will also output Bus Grant (BG) low to 
let the requesting device know that the bus will become available at the end of the current cycle. However, as 
we will see when we discuss the bus arbitration timing in detail, external devices or logic must monitor more tha n just 
the Bus Grant signal to determine when the bus will actually be available. The Bus Grant Acknowledge (BGACK) sig- 
nal must be input to the MC68000 by the device requesting the bus once that device takes control of the bus. 
BGACK must be held low until the device has completed its bus access operations. Thus BGACK is essentially a "bus 
busy" signal that lets the MC68000 (and other devices in the system) know that the bus is unavailable. 

The next three signals — E, VPA, and VMA — are provided so that the MC68000 can be easily interfaced to the 
standard and widely available 6800 family devices. 6800-based systems use a synchronous method of effecting 
transfers of data throughout the system. To accomplish this a system clock Enable (E) signal must be distributed to all 
6800 devices in the system so that all relevant data transfers may be synchronized to this clock signal. Thus the Ena- 
ble (E) signal provided by the MC68000 is the equivalent of the 6800 E signal. The frequency of E is equal to one- 
tenth that of the CLK input to the MC68000: the period for E is equal to 10 CLK periods — E is low for six CLK cycles 
and is high for four CLK cycles. 

The Valid Peripheral Address (VPA) signal is used by 6800-type devices in the system to inform the MC68000 
that a 6800-type data transfer is required. You must provide addr ess d ecoding logic in the system that determines 
when a 6800-type device is being accessed and that generates the VPA signal. When the MC68000 receives the 
VPA signal, it alters the data transfer timing so th at it is synchronous with the En able ( E) signal. The MC68000 
will then output the Valid Mem ory Address (VMA) signal at the appropriate time. VMA is another 6800-type sig- 
nal and will only be output if the VPA input signal has been asserted at the beginning of a data transfer operation. We 
will defer a detailed discussion of these three signals until later when we describe interfacing between the MC68000 
and the 6800-family devices. 

MC68000 TIMING AND BUS OPERATION 

The basic timing for the MC68000 is quite straightforward: instruction execution consists of a combination of 
internal cycles and bus access cycles. The total number of clock cycles required for each instruction is defined 
in the instruction set summary tables later in this chapter. The number of clock cycles required to perform opera- 
tions internal to the MC68000 are of little interest to other devices in the system since these operations are transparent 
to external logic. It is only when the MC68000 requires access to the system bus for such operations as instruction 
fetching, operand fetching, and operand storing that external devices become involved with MC68000 timing. 

The MC68000 uses memory mapped I/O. Therefore, bus accesses for data transfers between the MC68000 and 
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Figure 7-5. MC68000 Read Word Timing 



memory are the same as for those between the MC68000 arid I/O devices. Data transfers are defined as either 
read or write operations, with the transfer of data into the MC68000 defined as a "read" and the transfer of data from 
the MC68000 to external logic defined as a "write." 

Figure 7-5 illustrates the timing for a read word operation. For purposes of the following timing 
discussions, each clock period is sub-divided into two states. 



MC68000 

READ 

TIMING 



During state (SO) of the read word cycle, the address and data busses are in the high impedence 
state — the MC68000 is not using the System Bus at this point. Address information for the 
memory or I/O location is output at the beginning of state 1 (SI) on the Address Bus (A1-A23). Processor cycle status 
information is also output at this point on the FC0-FC2 pins. The Address Strobe (AS) signal is asserted at the beginning 
of state 2 an d can be used by external logi c to latch the information on the Address Bus. Simultaneously, the Upper 
Data Strobe (UDS) and Lower Data Strobe (LDS) signals are asserted to enable selection of both the most significant 
byte and least significant byte of a 16-bit word. You will note that these signals are not actually data "strobes" since 
there is no data ready to be input or output at this point; it is more accurate to think of them as memory select signals 
selecting the upper and/or lower byte of a 16-bit memory word. R/W is normally asserted, so this output does not 
change during a read cycle. 

The MC68000 now waits for the addressed memory or I/O device to present its data on the Data Bus. Whe n the da ta is 
ready, the external device must assert Data Ackno wledge ( DTACK) to the MC68000. The MC68000 expects DTACK and 
the requested data to be present by state 5 (S5). If DTACK is not present by S5, Wait states (SW) will be automatically 



7-12 



inserted into the read tinning c ycle a s illustrated in Figure 7-6. Once DTACK is true, the read cycle continues with S5. At 
the end of state 6 (S6), the AS, UDS, and LDS signals are negated. At this point the incoming data on D 0-D1 5 is l atch ed 
into an internal MC68000 register. External devices can use the negative-to-positive transition of AS, UDS, or LDS as 
the indication that they can remove data from the Data Bus. The MC68000 maintains the address information and func- 
tion code information through the end of state 7 (S7) to allow for signal skew within the system. Note that when the 
external de vice senses that the MC68000 has ca ptured the data from the Data Bus (by sensing the high-going transi- 
tion of AS, UDS, or LDS) that device must return DTACK high immediately so that it does not interfere with the begin- 
ning of the next bus cycle. 



If you refer to the Wait state insertion that can occur during read operations, as illustrated in MC68000 

Figure 7-6, you will see that the Wait states occur between state 4 and state 5. The WAIT STATE 

MC68000 will maintain valid address output on the addr ess Bus and will hold AS! UDS, and LDS i^^^^^— — 
low during any Wait states for as long as necessary until DTACK is asserted. You should note that 
there will always be an even number of Wait states inserted; all MC68000 operations are based on a complete CLK 
cycle and there are two "states" per CLK dycle. 
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Figure 7-6. MC68000 Wait States During Read Operations 
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Figure 7-7. MC68000 Read Byte Timing 



Timing for a read byte operation is illustrated in Figure 7-7. This figure shows first an even data byte and then an 
odd data byte being read by the MC68000. As you ca n se e, t he on ly difference between this timing and that illustrated 
for a read word operation in Figure 7 -5 is that only UDS or LDS is asserted and only eight lines of the data bus are 
utilized when you are r eading a byte: UDS is asserted and data is on lines D8-D15 when reading a byte located at an 
even address and LDS is asserted and data is on lines D0-D7 when reading a byte located at an odd address. You 
should not be misled by Figure 7-7 into thinking that the MC68000 always reads two consecutive bytes — an even 
byte and an odd byte. We have simply shown these two read operations consecutively to illustrate timing for both. 
Again, if the MC68000 requires a word of data, it will utilize the entire 16-bit Data Bus and read the full word in one 
operation. 
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Timing for a write word operation is illustrated in Figure 7-8. As was the case with read opera- 
tions, the address for the memory location or I/O device is output at the beginning of SI along 
with the appropriate function code indicating the current type of processor bus cycle. If the Data 
Bus was utilized by the MC68000 in the preceding cycle, the processor returns all of t_he data out- 
puts to the high impedence state during SI and then asserts the Address Strobe (AS) signal and outputs the Read/ 
Write (R/W) signal low. Once again, AS can be used to latch the address externally, and the R/W signal indicates to 
memory or I/O devices that the MC68000 will be placing data onto the Data Bus. No further signal activity occurs until 
t he M C68000 outputs the data on D0-D15 at the beginning of state 3 (S3). The Upper and Lower Data Strobe signals 
(UDS, LDS) are asserted at the beginning of state 4 (S4). During write operations, these two signals can be used as 
"strobe" signals since they indicate that the data on the Data Bus is valid. If the write operatio n is to p roceed unim- 
peded, external logic must re spond to the data strobe signals by asserting the Data Acknowledge (DTACK) signal by the 
beginning of state 7 (S7). If DTACK is not true by the beginning of S7, Wait states are automatically inserted by 
the MC68000, as illustrated in Figure 7-9. This "slow write" operation is the same as was illustrated for read 
operations except that the Wait states are inserted at a different point in the cycle. 

The MC68000 outputs the data on D0-D15 through the entire write operation. T he A ddress Strobe (AS) and data 
strobes (UDS, LDS) are negated at the beginning of state 9 (S9) and the Read/Write (R/W) signal is returned high at the 
end of S9. At that point, the Address Bus, Data Bus, and Function Code outputs are all returned to their high impedance 
state to free the System Bus for other uses. The external memory or I/O device that was accessed by the write operation 
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Figure 7-8. MC68000 Write Word Timing 
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Figure 7-9. MC68000 Wait States During Write Operations 



must release the Data Aclcnowledge (DTACK) signal after it has detected the positive-to-negative transition of the 
address or data strobe signals. This ensures that a subsequent bus cycle will not be impeded. 

Timing for write byte operation is illustrated in Figure 7-10. As you can see, t he only difference between this opera- 
tion and the write word timing illustrated in Figure 7-8 is the fact that only UDS or LDS is output while a byte is being 
written. 
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MC68000 READ-MODIFY-WRITE TIMING 

The read-modify-write cycle provided by the MC68000 is unusual among microprocessors, although it is fre- 
quently provided by minicomputers. The MC68000 uses the read-modify-write cycle only during the execution 
of the Test and Set (TAS) instruction. This instruction reads a byte of data, sets condition codes according to tiie 
contents of that byte, sets bit 7 of the byte, and then writes it back into memory. The TAS instruction is intended to be 
used as a means of providing "safe" communication between microprocessors in a multi-processor system. Safe com- 
munication is ensured with the TAS instruction since the read-modify-write cycle is non-interruptable. 
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Figure 7-10. MC68000 Write Byte Timing 
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Figure 7-11 illustrates the timing for a read-modify-write cycle. As you can see, it simply consists of the read- 
byte cycle followed by a standard write-byte cycle. There is one intervening clock period (S8. S9) between the 
read and write cycles and it is during this interval that the byte of data is modified internally for the subsequent 
write. Just as was the case with standard read and write, external logic must reply with DTACK at the proper time or 
else Wait states will automatically be inserted to lengthen the read or write operations. 

Note that in Figure 7-1 1 we have shown that either UDS or LDS will be asserted during the read-modify-write opera- 
tion. This is because the TAS instruction always operates on a byte of data, never on a word of data. 
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Figure 7-11. MC68000 Read-Modify- Write Timing 
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The MC68000 RESET OPERATION 

The MC68000 has an asynchronous reset input. You reset the microprocessor by holding the RESET and HALT signals 
low for at least 100 milliseconds. After the RESET and HALT signals are returned high, the MC68000 executes the 
following operations: 

1) The MC68000 reads the first four words from memory (bytes 000000 through 000007) and uses the con- 
tents of these locations to load the System Stack Pointer (SSP) and Program Counter (PC). The contents of 
these eight bytes from the beginning of memory are used as follows: 
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2) The interrupt mask in the Status register is set to all ones so that only level 7 interrupts will be enabled. No 
other registers are affected by the reset operation: therefore, when a reset is performed after applying power 
to the MC68000, all registers except SSP, PC, and the Status register will contain indeterminate values. 

3) Program execution begins, with the first instruction being fetched from the location indicated by the value 
loaded into the Program Counter. 

The sequence we just described is the typical externally-ini tiated reset operation similar to that provided by 
most microprocessors. You will recall, however, that the RES ET pin is bidirectional; when the MC68000 
executes a Reset instruction, a low-going pulse is sent out on the RESET pin. This software RESET pulse is low for 
124 CLK cycles. This instruction has no effe ct on the internal state of the MC68000, therefore none of its internal 
registers are affected. In this case, the RESET signal is being used to reset all other devices within the system under the 
control of the MC68000. 

THE MC68000 HALT STATE 

The MC68000 can be forced into a Halt state, at which time its Address Bus, Data Bus, and Function Code out- 
puts (FC0-FC2) are placed in the high-impedance state. This state is similar to the Hold state of the 8086 and the 
Stop state of the Z8000. The Halt state can be used to disable the MC68000 and thus free the System Busses for such 
activities as direct memory access or multi-processor operations. However, since the MC68000 includes an efficient 
bus arbitration system, it is more likely that the Halt state will be used to implement a hardware single-step mode. 

Figur e 7-12 illustrates the timing for the Halt operation. If the MC68000 is in the middle of a bus cycle when the 
HALT signal is input low, the bus cycle continues to its normal completion. At the end of the cycle the Address Bus, 
Data Bus, and FC0-FC2 signals are all placed in the high impedance stat e and the MC68000 halts. While it is in this 
halted condition, the processor does nothing — it merely waits for the HALT signal to return high. Note that the 
MC68000 provides no halt acknowledge indication to external logic. 

However, while the MC68000 is in the Halt state, its bus arbitration circuitry still operates. Since the MC68000 
will not be using the bus while it is halted, any bus request made to the MC68000 will be granted immediately. We will 
defer a detailed discussion of the bus arbitration circuitry until later. 



When the HALT signal is returned high, the MC68000 exits the Halt state within two clock cycles and can then begin 
another bus cycle. 

The execution of most MC68000 instructions requires multiple bus cycles to fetch t he ins truction and operands and, 
possibly, to store results of the instruction. Since the MC68000 will respond to the HALT input upon completion of 
any bus cycle, the halt sequen ce can occur between two instructions or in the middle of a single instruction. 
Therefore, if you are using the HALT input to implement a single-step mode of operation, you will be single- 
stepping by bus cycles rather than single-stepping by instructions. If you want to single-step by instructions, you 
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Figure 7-12. MC68000 Halt State Timing 



must use the Trace function of the MC68000. This function is implemented by setting the T-bit in the Supervisor byte 
of the Status register. We will describe the Trace operation in detail later. 



The HALT signal is bidirectional and will be asserted by the MC68000 if it initiates a Halt state rather than hav- 
ing external logic cause the Halt. The MC68000 will automatically enter the Halt state if there is a double-bus fault 
(we will discuss bus errors and doub le-bus faults in detail later). If the MC68000 has automatically entered the Halt 
state, the processor will outpu t HALT low a nd rem ain in this halted condition until an externally initiated reset opera- 
tion is performed using RESET. Thus, when HALT is output low by the MC68000, it indicates a catastrophic failure. 

THE MC68000 STOP STATE 

Following execution of the STOP instruction, the MC68000 microprocessor will enter a Stop state. The STOP 
instruction is permitted only when the MC68000 is operating in the Supervisor mode as indicated by the S-bit in the 
Status register. The Stop state is similar to the HALT state which we just discussed, since the microprocessor essen- 
tially does nothing while in this state. When the STOP instruction is executed, the Status register is loaded with a new 
value contained in the instruction. Next, the Program Counter is advanced to point to the next instruction and the 
MC68000 stops. 

No special signal or status is output by the MC68000 to identify t hat it is in the Stop state. The Stop state is ended by 
one of the exception conditions such as an interrupt request or a RESET. When an exception condition is detected by 
the MC68000, it leaves the Stop state and will process the exception condition. 
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THE MC68000 BUS CYCLE RERUN TIMING 

As we mentio ned earlier, the MC68000 can respond in two ways to a System Bus error, indicated by the asser- 
tion of BERR. it can perform exception processing (which we will describe later), or it can attempt to rerun the 
bus cycle which caused the bus error indication. If BERR is asser ted by itself, then the exception proce ssing (or soft- 
ware) method of handling the bus error is taken. However, if the BERR signal is accompanied by the HALT signal 
then the MC68000 recognizes this as a request to rerun the bus cycle. 

Figure 7-13 illustrates the timing for the bus cycle rerun operation, in t his figu re, we have shown a write cycle in 
progress, with the MC68000 waiting for the external device to respond with DTACK s o that the cycle can be completed. 
Instead of the expected acknowledge signal, external logic forces both the BERR and HALT signals low to indicate that 
the cycle was not successfully completed and that the MC68000 should rerun the cycle. 

The MC68000 proceeds to complete the cycle that was in progress and then enters the HALT state. The Address Bus, 
Data Bus, a nd Fu nctio n Cod e outputs are all placed in the high impedance state and th e mic roprocessor remains halted 
until both BERR and HALT are negated . Not e that BERR should be negated before HALT is negated to prevent the 
MC68000 fr om in terpreting the isolated BERR signal as another bus error — one that is expected to be handled in soft- 
ware. After HALT returns high, the MC68000 will proceed to repeat the cycle that was in progress when the rerun 
request was received; i.e., the same address, data, and function code information that was used in the previous bus 
cycle wilt be repeated. 
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Figure 7-13 shows the successful completion of the rerun cycle with DTACK being received in the expected 
interval. Of course, this will not always be the case — the attempt to rerun the bus cycle might also result in a bus 
error. Extern al log ic can contin ue to request that the cycle be rerun an unlimited number of times, using the com- 
bination of BERR and HALT. Yo u sho uld note, however, tha t if yo u are using the software exception processing 
method of handling the bus error (BERR asserted alone without HALT), then two successive bus errors are treated as a 
catastrophic error and the MC68000 will automatically enter the Halt state and remain there until reset. 

If the MC68000 is performing a read-modify-write cycle and a bus error is enco unte red, it will not rerun the 
cycle. This is done because the read-modify-write is only used during the Test and Set (TAS) instruction. The nature of 
this instruction demands complete execution cycle integrity, which might be violated if any of the bus cycles were 
repeated. If external logic requests a rerun of the read-modify-write cycle, the MC68000 will instead perform the bus 
error exception processing routine, which we will describe later. 

MC68000 BUS ARBITRATION LOGIC 

The bus arbitration logic provided by the MC68000 is straightforward. The MC68000 does not prioritize 
requests for bus accesses by external devices. The processor assumes that it is the lowest priority device in the 
system since it always grants bus access to any requesting device so long as the processor is not currently 
using the bus itself. Thus the MC68000 allows other devices to utilize the bus between instructions and between bus 
cycles of a single instruction. Since there is no built-in arbitration there should be some external bus arbitration logic in 
a system of any complexity to prioritize requests for the System Bus so that a high priority device is not superseded by 
low priority devices. 

There are three sign als asso ciated with the bus arbitration logic: Bus Request (BR), Bus Grant (BG), and Bus 
Grant A cknow ledge (BGACK). When the M_C68000 is using the System Bus without competition, the input signals — 
BR and BGACK — will be inactive and the BG output will be negated. 

Figure 7-14 illustrates the timing for the bus arbitration performed by the MC68000. Bus arbitration com- 
mences when an external device pulls the BR input low. When the MC68000 receives a bus request, it will respond 
by asserting BG one CLK period later. The only exception to this immediate response is when the MC68000 is in the 
initial stages of a bus cycle but has not yet asserted AS. In this case the MC68000 waits until one CLK period after AS 
has been asserted before it asserts BG; the response time in this case will be a maximum of three CLK periods. 

Obviously, the Bus Grant signal does not indicate that the bus is available for use by the requesting device at 
that point — the MC68000 may still be using the bus to complete its current bus cycle. Therefore the device 
requesting the bus must monitor several other signals to determine when the bus is actually available for its 
use. First, the external device must wait until AS is negated, ind icating that the MC68000 has completed the current 
bus cycle. The device requesting the bus must also wait until the DTACK signal is negated, since this indicates that the 
device involved in the cu rrent M C68000 cycle is no longer using the bus. However, in some systems it may not be 
necessary to monitor the DTACK signal. This is the case when system timing is such that you are always assured that 
all exte rnal devices will be off the bus when AS is negated. Lastly, the requesting device must check the state of the 
BGACK signal. If this signal is true, it indicates that some other device in the system has already been granted use of the 
System Bus and has not yet finished with it. Conversely, if BGACK is false, then the System Bus will be available for use 
at the end of the current cycle. 



After all of the signal conditions we have described are met, the device requesting the bus must assert BGACK. 
This informs the MC68000 that the requ esting de vice has taken control of the bus. You will note in Figure 7-14 
that the MC68000 does not wait for the BGACK signal before it relinquishes control of the bus: the Address and 
Data Busses, the Function Code outputs, AS, UDS, LDS, and R/W are all placed in the high impedance state as soon as 
the MC68000 has compl eted th e bus cycle that was in progress when the bus request was received. The device that is 
using the bus must hold BGACK low for as long as it requi res the bus. While an external device has control of the bus, 
external logic should prevent bus conflicts by monitoring_BGACK; at this poi nt the b ehavior of BR and BC is unimpor- 
tant. However, the device using the bus should negate its BR before negating BGACK to avoid an incorrect bus request. 



The MC68000 will maintain its output lines in the high impedance state until BGACK is negated, indicating that the 
external device is through with the bus. At that point the MC68000 is free to initiate another bus cycle. Note that if 
another bus request is pending at that point, the MC68000 will acquiesce to that bus request immediately without per- 
forming any bus cycles itself. 
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MC68000 EXCEPTION PROCESSING LOGIC 

All of Motorola's literature on the MC68000 refers to "exception processing" when discussing what we 
usually describe as the interrupt system in other microprocessors. They have chosen to use this nomenclature 
since the events that can cause "interrupts" in the MC68000 cover a much broader range than those usually 
associated with an interrupt request in a typical microprocessor. We will also use the "exception processing" 
nomenclature. 
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The MC68000 provides extensive exception processing logic. This logic is similar to that provided by the 8086 
and Z8000 in that a jump vector table is used to transfer program control to the appropriate handler program 
whenever an exception occurs. The biggest difference between the MC68000's logic and that of the Z8000 
and 8086 is that the number of events that can generate an exception in the MC68000 is greater than the num- 
ber of events that cause interrupts in Z8000. In addition, the MC68000 provides a 7-level priority structure for 
external interrupt requests. 

Before proceeding to describe the exception processing system, let us discuss the operat- 
ing modes of the MC68000, since these affect exception processing. As we mentioned pre- 
viously, the MC68000 can operate in either a Supervisor mode or a User mode. When the 



MC68000 

OPERATING 

MODES 



MC68000 is reset using the RESET input, it starts operating in the Supervisor mode. The pro- 
cessor remains in Supervisor mode until one of the following instructions is executed: Return from Exception 
(RTE), Move to Status Register (MOVE word to SR), AND Immediate to Status Register (ANDI word to SR), and 

Exclusive OR Immediate to Status Register (EORI word to SR). None of these instructions automatically causes the tran- 
sition to User mode of operation — rather, they are capable of changing the state of the S-bit in the Status register. If 
one of these instructions resets the S-bit, the MC68000 will begin operating in the User mode. 

Once the MC68000 is operating in the User mode, the only thing that can cause a transition back to the Super- 
visor mode is an exception. All exception processing is performed in Supervisor mode regardless of the current set- 
ting of the S-bit of the Status register. When the exception processing has been completed, the Return from Exception 
(RTE) instruction allows return to the User mode. 

A number of instructions, designated as "privileged," are reserved for the Supervisor mode. An attempt to execute one 
of these instructions in the User mode results in a "privilege violation" which is one type of exception. We will discuss 
these instructions and the privilege violation response later in this chapter. 

MC68000 EXCEPTION TYPES 

Exceptions originate in a variety of ways which can be divided into two general categories: 

1) Internally generated exceptions that result from the execution of certain instructions, or from internally 
detected errors. 

2) Externally generated exceptions which include bus errors, reset, and interrupt requests. 

The response of the MC68000 to the various types of exceptions is similar. Before we describe this response, let us look 
at the sources of exceptions since they go well beyond those provided by other microprocessors. 
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The internally generated exceptions to which the MC68000 responds can be further sub- 
divided into three categories: internally detected errors, instruction traps, and the Trace 
function. 

The following are the internally detected errors which will cause the MC68000 to initiate 
exception processing: 

1) Addressing errors. Whenever the MC68000 attempts to access word data, long word data, or an instruc- 
tion at an odd address, this is an address error since all such accesses must be on even address boundaries. 

2) Privilege violations. Again, some instructions are reserved for use only in the Supervisor mode. Exception 
processing will be initiated if you attempt to execute any of the following instructions when in the User 
mode: STOP, RESET. RTE, MOVE to SR, AND (word) Immediate to SR, EOR (word) Immediate to SR, OR 
(word) Immediate to SR, MOVE USP. 

3) Illegal and unimplemented opcodes. If an instruction is fetched whose bit pattern is not one of the defined 
instruction bit patterns for the MC68000, exception processing will be initiated. Two bit patterns are 
defined as unimplemented rather than illegal; if bits 15-12 are 1 01 or 1111, these are treated as unimple- 
mented instruction opcodes. If these opcodes are fetched, special exception processing is initiated which 
can allow you to use these unimplemerited instructions in your own software. 

Instruction traps are exceptions which are caused by the execution of instructions in your program. There is a 
standard TRAP instruction which is similar the Z8000 System Call instruction. There are four other instructions — 
TRAPV, CHK, DIVS, and DIVU — which will cause exception processing to be initiated if certain conditions, such 
as arithmetic overflows or divide by zero, are detected. 

The third type of internally generated exception occurs when the MC68000 is operating with the Trace func- 
tion. If the T-bit in the supervisor portion of the Status register is set, exception processing will be performed after each 
instruction. The Trace function is used for program debugging since you can analyze, by stepping through the program, 
the results of each instruction's execution. 
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There are three different types of externally generated exceptions 
1) 



Bus errors. When the BERR signal is pulled low by external logic (while HALT is high) 
exception processing is initiated. 



2) 
3) 
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Reset. When the RESET signal is asserted by external logic, exception processing is 

initiated. 

Interrupt request. This is the most f amilia r fornn of e xcep tion processing and is initiated by external logic 

via the three interrupt request lines (IPLO, IPL1, and IPL2). 

The different types of exceptions have different priorities, and processing of an exception 
depends on its priority. The following table lists the types of exceptions according to their 
relative priorities, and also defines when processing of each type begins. 



MC68000 

EXCEPTION 

PRIORITIES 



Priority 


Exception Source 


Exception Processing Response 


Highest 




Abort current cycle, then 
process exception 


RESET 

BERR (Bus Error) 

Address Error 




Trace 

Interrupt Request 
Illegal/Unimplemented Opcode 
Privilege Violation 


Complete current instruction, then 
process exception 


Lowest 


TRAP, TRAPV 

CHK 

Divide-by-zero 


Instruction execution initiates 
exception processing 



MC68000 
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TABLE 



The highest priority types of exceptions are Reset, Bus Error, and Address Error. Any of these exceptions will cause 
immediate termination of the current instruction, even within a bus cycle. The next group of exceptions — trace, inter- 
rupt requests, illegal/unimplemented instructions, and privilege violations — allow completion of the current instruc- 
tion before initiating exception processing. Note that interrupt requests include an additional prioritization which we 
discussed earlier. The lowest priority of exceptions are those that are caused by trap-type instructions. These instruc- 
tions can initiate exception processing as part of their normal execution. All of the instruction trap exceptions have 
equal priority since it is impossible for two of them to generate exceptions simultaneously. 
Central to the MC68000 exception processing sequence is a vector table that occupies 
1024 bytes (512 sixteen-bit words) of memory. This table occupies memory addresses 
OOOOOOie through OOOSFFie- Figure 7-15 illustrates the exception vector table. The table is 
organized as 256 four-byte vectors. Each vector is a 32-bit address which will be loaded into the 
Program Counter as part of the exception processing sequence. 
As you can see, a number of the vector table entries serve the defined types of exceptions which we have dis- 
cussed. The remaining entries of the vector table are reserved for use by Motorola and should not be used by your pro- 
gram if compatibility with Motorola software is desired. The first 64 exception vectors have predefined uses; this leaves 
192 vectors available to external interrupt requests — this should be more than enough for most applications. 
However, the first 64 vector locations are not protected by the MC68000; thus they can be used by external interrupts 
if a system requires it. 

MC68000 EXCEPTION PROCESSING SEQUENCES 

The general sequence of events performed by the MC68000 in response to an exception is the same regardless 
of the source of the exception. There are, however, some differences. Let us begin by examining the response 
to internally generated exceptions. 

If exception processing is initiated as a result of either the Trace function, a TRAP instruc- 
tion, an illegal or unimplemented opcode, or a privilege violation, the following steps occur: 

1) The Status Register contents are copied into an internal register. 

2) The S-bit in the Status Register is set, thus placing the MC68000 in the Supervisor 
mode of operation. 
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Memory 

Addresses 

(Hex) 

000000 
000002 
000004 
000006 
000008 
OOOOOA 
OOOOOC 
OOOOOE 
000010 
000012 
000014 
000016 
000018 
00001 A 
0000 10 
00001 E 
000020 
000022 
000024 
000026 
000028 
00002A 
O0OO2C 
00002E 
000030 
000032 



00005C 
00005E 
000060 
000062 
000064 
000066 
000068 
00006A 
000060 
00006E 
000070 
000072 
000074 
000076 
000078 
00007A 
00007C 
00007E 
000080 
000082 



OOOOBC 
OOOOBE 
OOOOCO 
O0OOC2 



OOOOFC 
OOOOFE 
000100 
000102 



0003FC 
O003FE 



SSP (High) 



SSP (Low) 



PCO (High) 



PCO (Low) 



PC2 (High) 



PC2 (Low) 



PC3 (High) 



PCS (Low) 



PC4 (High) 



PC4 (Low) 



PCS (High) 



PCS (Low) 



PCS (High) 



PC6 (Low) 



PC7 (High) 



PC7 (Low) 



PCS (High) 



PC8 (Low) 



PC9 (High) 



PC9 (Low) 



PC 10 (High) 



PC10 (Low) 



PC11 (High) 



PC11 (Low) 



PC 12 (High) 



PCI 2 (Low) 



PC23 (High) 



PC23 (Low) 



PC24 (High) 



PC24 (Low) 



PC25 (High) 



PC2S (Low) 



PC26 (High) 



PC26 (Low) 



PC27 (High) 



PC27 (Low) 



PC28 (High) 



PC28 (Low) 



PC29 (High) 



PC29 (Low) 



PC30 (High) 



PC30 (Low) 



PC31 (High) 



PC31 (Low) 



PC32 (High) 



PC32 (Low) 



PC47 (High) 



PC47 (Low) 



PC48 (High) 



PC48 (Low) 



PC63 (High) 



PC63 (Low) 



PC64 (High) 



PC64 (Low) 



PC255 (Low) 



PC255 (High) 
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Vector 25iQ- Level 1 Interrupt 
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Vector 31 10" Level 7 Interrupt/ 
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Figure 7-15. MC68000 Exception Vector Table 
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3) The T-bit in the Status Register is reset to disable tracing to allow for continuous execution when debug- 
ging using TRACE. 

4) The Program Counter contents are pushed onto the Supervisor Stack. The contents of SSP will be decre- 
mented by four since four bytes are required to store the 32-bit contents of PC. 

5) Status register contents are pushed onto the Supervisor stack; SSP contents are decremented by two, since 
the Status register is a 16-bit register. 

6) The new Program Counter contents are taken from the appropriate location in the interrupt vector table. 

7) instruction execution then begins at the location indicated by the new content of the Program Counter; this 
will be the first instruction of the exception processing program you have provided for that particular type 
exception. 



The way in which the MC68000 responds to an exception caused by a bus error or address 
error includes several steps in addition to those described in the preceding paragraphs. First, 
recall that either of these errors causes immediate termination of the bus cycle in progress. 
The next steps are the following : 
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1) The contents of the Status register are copied into an internal register. 

2) The S-bit in the Status register is set, placing the MC68000 in the Supervisor mode. 

3) The T-bit in the Status register is reset to disable trace operations. 

4) The contents of the Program Counter are pushed onto the Supervisor stack and the System Stack Pointer 
(SSP) is decremented by four. 

5) The contents of the Status register are pushed onto the Supervisor stack and the contents of SSP are decre- 
mented by two. 

6) The contents of the MC68000's instruction register, which constitute the first word of the instruction that 
was in progress when the bus error occurred, are pushed onto the Supervisor stack and SSP is decremented 
by two. 

7) The 32-bit address that was being used for the bus cycle which was terminated is also pushed onto the 
Supervisor stack and SSP is decremented by four. 

8) A word which provides information as to the type of cycle that was in progress at the time of the error is 
pushed onto the Supervisor stack and SSP is decremented by two. 

9) The Program Counter contents are taken from the appropriate interrupt vector — either the bus error vector 
or address error vector of the exception vector table. 

10) Instruction execution resumes at the location indicated by the new contents of the Program Counter. 

Figure 7-16 shows the order in which information is pushed onto the Supervisor stack as part of the exception 
processing for bus and address errors. The value saved for the Program Counter is advanced two to ten bytes beyond 
the address of the first word of the instruction where the error occurred according to the length of that instruction and 
its addressing information, if any. 

As you can see in Figure 7-16, the five least significant bits of the last word pushed onto the Stack provide infor- 
mation as to the type of access that was in progress when the bus error or address error occurred. The three least 
significant bits are a copy of the Function Code outputs during the aborted bus cycle. Bit 3 indicates the type of pro- 
cessing that was in progress when the error occurred. This bit is set for Group or 1 exception processing and reset for 
Group 2 exception and normal instruction processing. Bit 4 indicates whether a read (bit 4 set) or write (bit 4 reset) 
cycle was in progress when the error occurred. If an error occurs during the exception processing of a preceding bus 
error, address error, or reset operation, the MC68000 will enter the Halt state and remain there. 

All of the information that is pushed onto the Supervisor stack as part of the bus and address error exception 
processing sequence is intended to aid you in analyzing possible sources of the error. Either of these errors implies 
a serious system failure and it is not likely that you will be able to return to normal program execution. 



An external reset causes a special type of exception processing. After the RESET input has 
been pulsed low the following steps occur: 
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1) The S-bit in the Status register is set, placing the MC68000 in the Supervisor mode. 

2) The T-bit in the Status register is reset to disable the trace function. 

3) All three interrupt mask bits in the Status register are set, thus specifying the interrupt priority mask at level 
seven. 

4) The Supervisor Stack Pointer (SSP) is loaded with the contents of the first four bytes of memory (addresses 
000000-000003). 
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Figure 7-16. MC68000 System Stack After Bus Error or Address Error 



5) The Program Counter (PC) is loaded from the next four bytes of memory (addresses 000004-000007). 

6) Instruction execution commences at the address indicated by the new contents of the Program Counter, 
which should reference your power-up/ reset initialization program. 1 MC68000 

INTERRUPT 
REQUEST 
EXCEPTION 
PROCESSING 



The last type of exception processing we will discuss is the sequence initiated by the stan- 
dard interrupt reques t. An exte rnal device requests an interrupt by encoding an interrupt 
request level on the IPL0-IPL2 inputs. The MC68000 compares these inputs to the interrupt 
mask bits in the Status register. If the encoded priority level is less than or equal to the one 
specified by the three-bit mask, the interrupt request will not be recognized by the MC68000. If the encoded interrupt 
level is a higher priority than the level established by the interrupt mask (or if a level seven interrupt request is 
input) then the interrupt will be processed. The MC68000 responds to the allowed interrupt request as soon as it 
completes the instruction execution currently in progress. Upon completion of the current instruction, the following 
steps occur: 

1) The contents of the Status register are saved internally. 

2) The S-bit in the Status register is set, placing the MC68000 in the Supervisor mode. 

3) The T-bit in the Status register is reset to disable the Trace function. 

4) The interrupt ma sk bits i n the Status register are updated to the level of the interrupt request that is 
encoded on the IPL0-IPL2 inputs. This allows the current interrupt to be processed without being inter- 
rupted by lower priority events. 

5) The MC68000 then performs an interrupt acknowledge bus cycle. This cycle serves two functions; first, the 
processor lets the requesting device know that its interrupt request is being serviced, and second, the pro- 
cessor fetches an exception vector byte from the requesting device. Figure 7-17 shows the timing for this 
interrupt acknowledge/vector fetch cycle. This cycle is esentially a read cycl e with a few minor 
differences. First, address lines A1 through A3 will reflect the states of the IPL0-IPL2 inputs so that external 
logic can determine which interrupt request is being processed. All of the other address outputs are set dur- 
ing the interrupt acknowledge cycle. The requesting device responds to the MC68000 by placing a byte of 
exception vector data on the lower half of the data bus. The Data Transfer Acknowledge (DTACK) signal is 
used to effect this transfer of data just as with a normal read cycle. Throughout the interrupt acknowledge 
cycle, the Function Code outputs (FC0-FC2) will be set high since this represents the interrupt acknowledge 
function code. After the vector byte has been read from the interrupting device, the MC68000 proceeds 
with the following exception processing steps. 

6) The contents of the Program Counter are pushed onto the Supervisor stack and SSP is decremented by four. 
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Figure 7-17. MC68000 Interrupt Acknowledge/Vector Fetch Cycle 
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7) The contents of the Status register are pushed onto the Supervisor stacic and SSP is decremented by two. 

8) The Program Counter is loaded with four bytes of data from the appropriate location in the exception vector 
table. The address for this location is derived as shown in the following illustration: 



Vector No. from 
interrupting device 



D7 D6 D5 D4 D3 D2 D1 DO 

II 



Address Outputs- 




oJ6|o|o|o|o|o|o|o|o|oio|o|o| I I I I I I I loTo 



A23 



A1 A9 A8 A7 A6 A5 A4 A3 A2 A1 AO 
-Address range = OO0O00-OOO3FC 



MC68000 
SPURIOUS 
INTERRUPT 



MC68000 
AUTOVECTOR 
INTERRUPT 
RESPONSE 



The eight bits of data that were read from the requesting device as part of the interrupt acknowledge cycle 
are used to form address bits A2 through A9. The two least significant bits and bits A1 through A23 will all 
be set to zero. Thus, addresses 000000-]6 through OOOSFC-ig can be generated. If you refer to Figure 7-15, 
you will see that these are the upper and lower boundaries of the exception vector table. Under normal cir- 
cumstances a requesting device should limit itself to producing vectors corresponding to the address range 
OOOOFC-16 through OOOSFCie since the lower addresses in the vector table have preassigned uses. 

After the Program Counter has been loaded with the new value from the exception vector table, instruction execution 
commences at the location indicated by the new contents of the Program Counter; this will be the first instruction of 
your interrupt processing routine for the particular device requesting the interrupt. 

There are two variations to the interrupt request processing sequence we have just de- 
scribed. First, if during the interrupt acl<nowledge bus cycle the requesting device responds 
by asserting BERR instead of DTACK, the MC68000 treats this as an indication that the cur- 
rent interrupt request is a spurious one, and it will use vector 24 in the exception vector table to 
load the Program Counter. 

The second variation on interrupt request processing is the autovector response. If you refer 
to Figure 7-1 5, you will see that seven vector locations are provided in the exception vector 
table for autovectors, corresponding to the seven interrupt priority levels. These vectors 
will be used if the device requesting an interrupt r espo nds to the interrupt acknowledge bus 
cycle by asserting the Valid Peripheral Address (VPA) signal instead o f supp lying a byte of vector data. If this 
occurs, the MC68000 will respond by asserting the Valid Memory Address (VMA) signal. The processor will then use 
the appropriate autovector from the exception vector table to obtain a new Program Counter value. This autovector 
response wa s provided specifically to emulate the interrupt timing sequence expected by 6800-familY peripheral 
devices. The VPA/VMA sequence is the standard 6800 microprocessor interrupt sequence. Of course a non-6800- 
family device in the system could also exploit this autovector capability should it be advantageous. 

MC68000 ADDRESSING MODES 

The MC68000 utilizes 14 different addressing modes which can be grouped into six basic types. These are: 

1) Direct Register Addressing 

a) Data Register Direct 

b) Address Register Direct 

2) Direct Memory Addressing 

a) Absolute Short 

b) Absolute Long 

3) Indirect Memory Addressing 

a) Register Indirect 

b) Post-increment Register Indirect 

c) Pre-decrement Register Indirect 

d) Register Indirect with Displacement 

e) Register Indirect with Index and Displacement 

4) Implied Register Addressing 
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5) Program Counter Relative Addressing 

a) PC-relative with Displacement 

b) PC-relative with Index and Displacement 

6) Immediate Data Addressing 

a) Immediate 

b) Quick Immediate 

These addressing modes help create a powerful and efficient instruction set. In particular, two useful features of 
the MC68000 addressing are that any address register may be used for direct or indirect addressing, and any register 
may be used as an index register. 

The general format of a single effective address instruction operation word is shown below. The two least signifi- 
cant 3-bit fields determine the effective address. These fields are the mode field (bits 3-5) and the register field (bits 0- 
2). 



15 


14 


13 


12 


11 


10 


9 


8 


7 


6 


5 
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3 


2 


1 


- 


E 


X 


X 


X 


X 


X 


X 


X 


X 


X 


m 


m 


m 


r 


r 


3 



-Bit No. 



-Register Field 
-Mode Field 



In some cases, the information contained in these two fields may be appended to fully specify the operand. In this 
case, one or two additional words are appended onto the instruction. This additional information is called the effec- 
tive address extension, and its format is: 



"S E 

II 



.9 E 
!2 w 



Operation Word 



Immediate Operand 
(if any, one or two words) 



Source effective address extension , 
(if any, one or two words) 



Destination effective address extension 
(if any, one or two words) 



•16 Blts- 



We will now discuss the addressing modes in detail. The following abbreviations are used within this section. 



An 

CCR 

dddd 

Dn 

EA 

N 

PC 

PPPP 

qqqq 

xxxx 

yyyy 

zzzz 

Rn 

rrr 

SP 

SR 

SSP 

ssss 

USP 



Address register n (0 < n < 7) 

Condition code half of the Status register 

displacement value 

Data register n (0 < n < 7) 

effective address 

operand size in bytes (1,2, or 4) 

Program Counter 



any four hex digits 

any address or data register n (0 < n < 7) 

the 3-bit value of n 

the active Stack Pointer 

Status register 

Supervisor Stack Pointer 

sign extension digits 

User Stack Pointer 
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Register Direct Addressing 

This addressing mode requires that the operand involved be contained in one of the eight Data 
registers or one of the eight address registers (Mode = 0012)- 



MC68000 
REGISTER 
DIRECT 
ADDRESSING 



Memory 




WW 



ssxxyy 
ssxxyy + 1 
ssxxyy + 2 
ssxxyy + 3 



>■ Operation word 
>- Extension word 

Operand (1, 2, or 4 bytes) 



Byte 



EA = Sign extended value of the extension word 
Mode =1112 
Register = OOO2 



Figure 7-18. MC68000 Absolute Short Direct Memory Addressing 



Memory 






1 




x 


X 


1 


1 


1 


001 


( 


PP 


^ } 


qq 






XX 




yy 






j 


ppqqxxyy 




ppqqxxyy + 1 




ppqqxxyy + 2 




ppqqxxyy + 3 





Operation word 
• First extension word 
Second extension word 

Operand (1 , 2, or 4 bytes) 



Byte 



EA = Concatenation of extension words 
Mode =1112 
Register = 001 2 



Figure 7-19. MC68000 Absolute Long Direct Memory Addressing 
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Data Register Direct 

EA = Dn 
Mode = OOO2 



Address Register Direct 

EA = An 
Mode = 001 2 



Absolute Data Addressing 



MC68000 
ABSOLUTE 
DATA 
ADDRESSING 



There are two forms of this addressing mode. The short form is called absolute short addressing, 
while the longer format is called absolute long. 

Absolute short. One extension word is necessary for this addressing mode. The address of the 
operand is the sign extended value of the extension word. Figure 7-18 illustrates the absolute 
short addressing mode. 

Absolute long. Two words of extension are required for this addressing mode. The address of the operand is the con- 
catenation of the two extension words; the first is the high-order portion, the second is the low-order portion. Figure 7- 
19 illustrates the absolute long addressing mode. 



MC68000 
REGISTER 
INDIRECT 
ADDRESSING 



Register Indirect Addressing 

The five variations of this addressing mode each reference an operand in memory. 

Address register indirect. In this mode, the address of the operand is the contents of the 
specified Address register. Figure 7-20 illustrates the address register indirect mode. 

Address register indirect with postincrement. In this mode, the address of the operand is the 
contents of the specified Address register. After the instruction using this mode is executed, the contents of this 
register are incremented by one, two, or four depending on the size of the operand. If the Address register is A7 (SP) 
then the address is incremented by two regardless of the operand size, because the Stack Pointer must be kept on a 
word boundary. Figure 7-21 illustrates the Address register indirect with postincrement mode. 

Address register indirect with predecrement. This addressing mode is similar to the previous one vyith the exception 
that the contents of the specified Address register are decremented before they are used to reference the operand. 





Address Registers 


" ^^ xxyyyy 
xxyyyy + 1 
xxyyyy + 2 
xxyyyy + 3 


IVIemory 


> Operation word 
Operand (1, 2, or 4 bytes) 


AO 
A1 
A2 
A3 
A4 
A5 
A6 
A7 








X 


■• 





' 





' 


' 


' 








xxxxyyyy 






















EA = [An 
Mode = 
Register = 


IO2 
: n 


Byte 



Figure 7-20. MC68000 Address Register Indirect Memory Addressing 
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Address Registers 


Ng 




Memory 


> Operation word 
Operand (1 , 2, or 4 bytes) 


AO 
A1 
A2 
A3 
A4 
A5 
A6 
A7 




^^.^^ xxyyyy-/ 
xxyyyy + 1 
xxyyyy + 2 
xxyyyy + 3 


1 




X 


X01 


' 


' 


' 


' 










xxxxyyyy ^ 




"^ 












{In this example rrrr =101) 






EA = [An] 
[An] = [An] + N 
Mode = 01 12 
Register = n 




Byte 



Figure 7-21. MC68000 Address Register Indirect with Postincrement Addressing 







Address Registers 




Memory 

1 


> Operation word 
Operand (1, 2, or 4 bytes) 


AO 
A1 
A2 
A3 
A4 
A5 
A6 
A7 






1 


xxxxyyyy ^ <^^ 




x 


^ 


1 








^ 


' 


M 


V 








^"^►-N-S. 1 1 




V,^ xxyyyy - N 
xxyyyy - N + 1 
xxyyyy - N + 2 
xxyyyy - N + 3 


















(In this example rrrr = 001) 






[An] = [An] - N 
EA = [An] 
Mode = 1 0O2 
Register = n 




Byte 



Figure 7-22. MC68000 Address Register Indirect with Predecrement Addressing 



Again, if A7 is specified then the address is always decremented by two. Figure 7-22 illustrates the address register 
indirect with predecrement mode. 

Address register indirect with displacement. One word of extension is required with this addressing mode. The 
address of the operand is the sum of the contents of the specified Address register and the sign-extended 16-bit dis- 
placement word contained in the extension word. Figure 7-23 illustrates the address register indirect with displace- 
ment mode. 

Address register indirect with index and displacement. This addressing mode requires one word of extension which 
is formatted as shown in Figure 7-24. The operand address is the sum of the specified address register, the sign-extend 
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Address Registers 



Memory 



xxxxyyyy 




x[x|i |o 



(In this example rrr = 010) 

EA = [An] + dddd (sign extended) 
Mode= 101 2 
Register = n 



zzzzzzzz 
zzzzzzzz + 1 
zzzzzzzz -h 2 
zzzzzzzz + 3 



dd 



dd 



Byte 



>^ Operation word 
>^ Displacement word 

Operand (1 , 2, or 4 bytes) 



Figure 7-23. MC68000 Address Register Indirect with Displacement Addressing 



15 14 13 12 11 10 9 8 



1 



D/A 



Register 



W/L 



Displacement Integer 




■Bit No. 



Displacement (-128 through +127) 
Not used, always 

Index size: 

= sign extended low-order 

integer in index register 

1 = long value in index 

register 

Index register number 
Index register indicator: 

= data register 

1 = address register 



Figure 7-24. MC68000 Extension Word Format for Indexing 
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Address Registers 



Memory 



AO 
A1 
A2 
A3 
A4 
A5 
A6 
A7 



DO 
D1 
D2 
D3 
D4 
D5 
D6 
D7 





X X 1 1 Or^riri 


SrjrjrjUIOOO 


d d 



» Operation word 
■ Extension word 

Operand (1,.2, or 4 bytes) 



Data Registers 



ppppqqqq 




(In this example D/A = and r2r2r2 = 001 therefore the 
index register is D1 ; r^ r^ r^ = 110 which indicates A6 is used) 

EA = [An] + [Rn] + dd (sign extended) 
Mode = 1 1 02 
Register = n^ 



Figure 7-25. MC68000 Address Register Indirect with Index and Displacement Addrescing 



displacement integer in the least significant byte of the extension word, and the contents of the Index register. Address 
formation for the Address Register Indirect with Index and Displacement is illustrated in Figure 7-25. 



Implied Register Addressing 

There are some instructions that implicitly refer to a specific register. These registers are the Pro- 
gram Counter (PC), the Stack Pointer (SP-SSP or USP), and the status register (SR). Table 7-5 
shows those instructions in which a register holding the operand is implied. 

Program Counter Relative Addressing 

There are two formats for PC-relative addressing. Both require one word of extension and both 
provide displacement. The second format includes indexing in additional to displacement. 



MC68000 
IMPLIED 
REGISTER 
ADDRESSING 



MC68000 

PROGRAM 

COUNTER 

RELATIVE 

ADDRESSING 
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[PC] - 2 
[PCI - 1 
^[PC] 

oopppccc .•^:^tpc] + 1 

+ ssssdddd .^-^ I ^^^^ * ^ 
zzzzzz 

^"^ ^ zzzzzz 
zzzzzz + 1 
zzzzzz + 2 
zzzzzz + 3 

EA = [PC] + dddd (sign extendec 
Mode =1112 
Register = 0102 


Memory 


> Operation word 

> Extension word 

Operand (1 , 2, or 4 bytes) 




xlx|lilll|0ll|0 


dd 


dd 


1 

1 










) Byte 



Figure 7-26. MC68000 Program Counter Relative Addressing 



Data Registers 



Memory 




Operation word 



Extension word 



Operand (1, 2, or 4 bytes) 



(In this example D/A = O and rrrr = 01 1, therefore the selected index register is D3.) 

EA = [PC] + [Rn] + dd (sign extended) 
Mode =1112 
Register = 0112 



Figure 7-27. I\/IC68000 Program Counter-Relative with Index and Displacement Addressing 
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Byte 




00000000 1 Operand 
or 




Extension word(s) 


Word 




Operand 
or 






Long Word 


Operand (high order half) 




Operand (low order half) 




v^ 


1 


^ 




EA = Not required; 
Mode =1112 
Register = 1 0O2 


Word 
the operand is part of the instruction 







Figure 7-28. MC68000 Immediate Data Addressing Extension Words 



The value contained in the Program Counter which is used in address calculation is the address of the extension 
word. 

PC-relative with displacement. This addressing mode generates an effective address by summing together the value 
of the Program Counter and the sign extended value of the extension word. Figure 7-26 illustrates the PC-relative with 
displacement mode. 

PC-relative with index and displacement. This mode requires an extension word format similar to that required by 
the address register indirect with index and displacement mode (see Figure 7- 24). The address is calculated as shown 
in Figure 7-27. 



MC68000 
IMMEDIATE 
DATA 
ADDRESSING 



Immediate Data Addressing 

The operand for immediate data addressing is the value that immediately follows the instruction 
word. Thus, depending on the size of the operand, either one or two extension words will be 
necessary, as illustrated in Figure 7-28. 

THE MC68000 INSTRUCTION SET 

Table 7-6 summarizes the instruction set of the MC68000. Instruction object codes and execution times are 
given alphabetically in Table 7-7. Instruction object codes are given numerically in Table 7-8. 

When compared to other microprocessor instruction sets, the MC68000 instruction set might seem quite large: 
over 300 instructions are listed in Table 7-6. However, if you examine this table closely, you will see that slight varia- 
tions of the same instruction mnemonic may appear several times. These are different forms of the same instruction. 
There are actually 56 basic instructions provided in the MC68000. We have listed all the variations of a single 
instruction as though they were distinct instructions in order to make our description of the instruction set consistent 
with similar ones for other microprocessors. 

One of the most significant characteristics of the MC68000 instruction set is its orderliness. Despite its apparent 
complexity, this instruction set should be relatively easy to learn, since the variations are consistent and therefore pre- 
dictable. These variations are due to the different addressing modes available and to the MC68000's ability to handle 
five different data types. Since there are really only 56 basic mnemonics that you must learn, it is more likely that you 
will use all of the instructions in the way that they were intended and thus obtain the full power of the instruction set. 

Let us examine the MC68000 instruction set by instruction categories, as given in Table 7-6. 

One thing to keep in mind is that the MC68000 uses memory-mapped I/O: therefore there are no separate I/O 
instructions. The primary memory reference instructions will also be used to accomplish 1/0. 

The basic format of all instructions is the same. The op-code for every instruction is one word. Additional extension 
words are required when the addressing modes specified use constants (immediate operands), absolute addresses, or 



7-38 



displacements. Accordingly, an instruction can be anywhere from 2 to 10 bytes in length. The number of bytes for 
each instruction is listed in Table 7-6. 

All of the primary memory reference instructions have byte, word, and long word versions. Secondary memory 
reference instructions can use most of the memory addressing modes. There are byte, word, and long word ver- 
sions of most, but not all, of these instructions. 

The Move instruction provided by the MC68000 allows data nnovement between registers, from register to nnemory, 
from memory to register, and directly from one memory location to another. The Move Multiple Registers (MOVEM) 
instruction allows all of the MC68000 register contents to be quickly saved in memory or restored from memory. 

The MC68000 does not provide a block move instruction such as those available with the 8086 and the Z8000 
microprocessors. However, since the Move instructions can move data from one memory location to another, it is 
simple to move blocks of data by using the Move instruction in conjunction with the Decrement and Branch 
(DBcc) instruction. 

Both signed and unsigned multiply and divide instructions are included in the instruction set. In comparison, the 
Z8000 provided only unsigned multiplication and division. However, the Z8000 provides 32-bit multiplication and divi- 
sion while the MC68000 can only multiply two 1 6-bit operands producing a 32-bit result, or divide a 32-bit dividend by 
a 16-bit divisor. The divide instructions reference the dividend in one of the Data registers: the divisor may 
reside in memory or in another Data register. Both the divisor and the dividend are treated as signed binary numbers 
in the DIVS instruction and as unsigned binary numbers in the DIVU instruction. After the division instruction has been 
executed, the quotient is returned in the low-order half of the dividend register and the remainder is returned in the 
high-order half of the dividend register. 

The multiply instructions also have only a word version: there is no long word version. As with the division, there 
is a signed (MULS) and unsigned (MULU) version of the multiply instructions. One of the operands must reside in the 
least significant half of a Data register while the other operand can be either a memory word, the lower half of another 
Data register, or can consist of immediate data included as part of the instruction. Upon completion of the multiply 
operation, the 32-bit product is returned in the source operand Data register. 

The MC68000 includes standard Jump and Jump to Subroutine instructions (JMP and JSR) which use specific 
addresses for loading the Program Counter. There are also the Branch Always and Branch to Subroutine instruc- 
tions (BRA and BSR) which cause a transfer of program control relative to the Program Counter's current contents. 

The Trap instruction is the MC68000's equivalent of the System Call instruction provided by the Z8000. You 

will recall from the earlier discussion of the MC68000 exception processing logic that the Trap instruction automat- 
ically switches the MC68000 into the Supervisor mode, which utilizes a separate Stack Pointer to isolate the operating 
system from application programs. 

The MC68000 also provides several instructions that are specifically designed to simplify implementation of 
higher level languages. These instructions are unique to the MC68000. The Link (LINK) and Unlink (UNLK) 
instructions can be used to maintain a linked list of local data and parameter areas on the Stack and thus 
simplify operations where there are frequent interrupts of nested subroutines. 

The Link instruction uses the System Stack Pointer (SFP), one of the other Address registers, as a 'frame pointer" and a 
displacement value. This instruction will typically be used at the beginning of a subroutine. The Link instruction first 
pushes the current value of the frame pointer onto the Stack. The current value of the Stack Pointer is then loaded into 
the frame pointer so that it now points to the top of the current Stack. Finally, the displacement value included with the 
Link instruction is used to decrement the System Stack Pointer so that it is displaced to clear a space in memory for 
storage of such things as local variables and parameters. These variables can then be accessed via the frame pointer. 
The Unlink (UNLK) instruction is used to clean up the Stack at the end of a subroutine and would be executed just prior 
to returning to a higher level subroutine. The Unlink instruction loads the System Stack Pointer with the contents of the 
frame pointer. The frame pointer is then loaded with the address pulled off the Stack. Thus, both the frame pointer and 
the System Stack Pointer will be restored to the values they held before the subroutine was called. 
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ABBREVIATIONS 

Following are the abbreviations used for instruction formats and operation descriptions. 

addr Direct address (16 or 32 bits) 

An Address registers, n = 0-7 (8. 16, or 32 bits, depending on the instruction size) 

bitb Bit number of byte 0-7 

biti Bit number of long word 0-31 

cc Condition code: 



CC 
CS 
EQ 
F 
GE 

GT 

HI 

LE 

LS 
LT 
Ml 
NE 
PL 
T 
VC 

vs 



Carry clear 

Carry set 

Equal 

False 

Greater than 

or equal 

Greater than 

High 

Less than or 

equal 

Low or same 

Less than 

Minus 

Not equal 

Plus 

True 

No overflow 

Overflow 



0100 
0101 
0111 
0001 
1100 

1110 
0010 

1111 

0011 
1101 
1011 
0110 
1010 
0000 
1000 
1001 



CCR Condition Code register — the low-order byte of the Status register 

count Shift count (1-8) 

dadr Destination address, which may be any of the following addressing modes: 



dAn 

aDn 

dataS 

dataS 

data 16 

data32 

Dn 

d8 

d16 

jadr 
label 
madr 
reg-list 



rd 
rs 



(An) 
(An)-F 

-(An) 

d16(An) 

d8(An,i) 
addr 



Register indirect 
Register indirect with 
postincrement 
Register indirect with 
predecrement 
Register indirect with 
displacement 
Register indirect, indexed 
Direct address 



Destination Address register. This form is used only when there are two An operands. 

Destination Data register. This form is used only when there are two Dn operands. 

3 bits of immediate data 

8 bits of immediate data 

16 bits of immediate data 

32 bits of immediate data 

Data register, n = 0-7 (8, 16, or 32 bits, depending on instruction size) 

8-bit address displacement. Required, even if zero on indexed instructions. 

16-bit address displacement 

Index register (An or Dn) 

Jump address — same as sadr except no (An)-I- or —(An) 

Address label 

Multiple-instruction address — same as dadr except no (An)-I- or -(An) 

Register list naming one or more registers, each item in the list separated by a comma. Items may 

have the form: 

Dn Single data register 

An Single address register 

rn-i-rn Range of registers 

Destination registers (dDn or dAn) 

Source register (sDn or sAn) 
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sadr Source address, which may be any of the following address modes: 

(An) Register indirect 

(An)+ Register indirect with 

postincrement 
—(An) Register indirect with 

predecrement 
d16(An) Register indirect with 

displacement 
d8(An,i) Register indirect, indexed 

addr Direct address 

label Program relative 

label (i) Program relative, indexed 

sAn Source Address register. This form is used only when there are two An operands. 

sDn Source Data register. This form is used only when there are two Dn operands. 

SR Status register (16 bits) 

USP User Stack Pointer. Note that this is Register A7. 

vector Trap address vector, the memory location containing the address of the Trap routine. 

[[ 11 The contents of the memory location whose address is contained in the designated register 

(indirect memory addressing, or implied addressing). 

[ ] The contents of a register or memory location (register addressing or direct memory addressing). 

For example: 

[Dn] - [[An]] 

indicates that the contents of the memory location addressed by Register An are loaded into Dn, 
whereas: 

[Dn] - [An] 

indicates that the contents of Register An itself are loaded into Dn. 

"x Complement the value of x. 

X <y-z > Bits y through z of x. For example, Dn <0-7 > means the low-order byte of Dn. If the z term is omit- 
ted, then only the bit selected by y is being referenced. Thus Dn<0> means the least significant 
bit of Dn. 

+ Add 

- Subtract 

X Multiply 

-5- Divide 

A Logical AND 

V Logical OR 

V Logical Exclusive-OR 
= Equals 

♦— Data moves in the direction of the arrow 

" ► Data are exchanged between two locations 

INSTRUCTION MNEMONICS 

Table 7-6 summarizes the MC68000 instruction set. The MNEMONIC column lists the instruction mnemonic (e.g., 
MOVE, ADD, JMP). The OPERAND(s) column lists the operands used with the instruction mnemonic. 

The fixed part of an assembly language instruction is shown in UPPER CASE. The variable part (register number, 
address, immediate data, etc.) is shown in lower case. 

The BYTES and CLOCK CYCLES are repeated in this table for reader convenience. Refer to "Instruction Object Code 
Tables" and the text accompanying Table 7-7 for a description of these entries. 
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STATUS 

The effect of instruction execution on the status bits is listed in Table 7-6. The status bits are: 

T — Trace mode 

S — Supervisor state 

X — Extend bit 

N — Negative (or Sign) bit 

Z — Zero bit 

V — Overflow bit 

C — Carry bit 

The following symbols are used in the STATUS columns: 

X — flag is affected by operation 
(blank) — flag is not affected by operation 
1 — flag is set by operation 
— flag is cleared by operation 

OPERATION PERFORMED 

This column shows the sequence of operations that occurs when the instruction is executed. (Instruction fetches are 
not shown, nor is the incrementing of the Program Counter for the purpose of instruction fetches.) Each operation is 
generally shown in the following form: 

destination -^ source 

indicating that the source contents moves to the destination, replacing the destination contents. For example, the LEA 
instruction operation is: 

[An] — jadr 

The effective address, which may be any of the jadr forms, is loaded into the specified Address register. 

Following the arrow sequence is a description of the operation in words. 

Alternate Mnemonics 

The MC68000 instruction set allows a choice of mnemonics for many operations. An "I" can be appended to the 
instruction mnemonic for an immediate operation. An "A" can be appended to the instruction mnemonic for an 
Address register operation. An ".S" can be appended to force a short-form conditional branch instruction. 

Mnemonic choices are summarized in Table 7-5 under these headings: 

PRIMARY MNEMONIC Lists the nominal mnemonic form 

ALTERNATE MNEMONIC Lists the alternate choices that can be used in place of 

the primary mnemonic. 
OPERAND Shows the operand category to which the primary and 

alternate mnemonics apply, xx is any allowed operand 

selection. 
DESCRIPTION Identifies the operation. 

For simplicity, only the primary mnemonics are shown in the instruction set tables that follow. 

Note that there are no mnemonic alternates for the instruction variations X (Extend), M (Multiple), and P (Peripheral 
Data). These suffixes cannot be omitted from their respective instruction mnemonics. 

Bear in mind that the assembler will select the "Quick" version of an instruction (e.g., MOVEQ, ADDQ, SUBQ) whenever 
possible. Thus you can use the alternates for these mnemonics — the more general MOVE, ADD and SUB — without 
sacrificing any opportunities for code shortening. 

For example: MOVE.L #40,D2 
is coded as: MOVEQ #40,D2 

Another example: ADD #1, DO 
is coded as: ADDQ.W #1,D0 
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MC68000 INSTRUCTION OBJECT CODE TABLES 

The object code for each MC68000 instruction is shown alphabetically by instruction mnemonic in Table 7-6. The 
object codes are listed in numerical order in Table 7-7. 

For instruction words which have no variations, object codes are represented as four hexadecimal digits; for example, 
4E71. 

For instruction words with variation in one of the two bytes, the object code is shown as a combination of lower case 
variables, hex digits, and binary digits. Each byte of an instruction word in Tables 7-7 and 7-8 is subdivided into two 
"nibble" fields (1 nibble = 4 bits). If a single digit appears in a nibble field, it is a hexadecimal digit. If four digits, or a 
combination of digits and lower-case variables (for example, 1 rrr), appear in a nibble field, each digit represents a single 
bit. 

Note that some lower-case variables are used to represent hexadecimal digits rather than binary digits. When four of 
these hexadecimal variable characters (for example xxxx or yyyy) are used to represent a 16-bit word, they will appear 
grouped together in the center of the 2-byte column comprising that word. 

INSTRUCTION EXECUTION TIMES 

Table 7-7 lists the instruction execution time in clock cycles. Each cycle = 125 nanoseconds (when fcLK =8.0 MHz). 

The abbreviations and notations used in the "clock cycles" column are defined as follows; 

-l-ea Effective address overhead. This is the additional time required to execute the instruction for addressing 

modes that take longer to execute than the nonninal register indirect address. The following are the addi- 
tional clock cycles required: 



Addressing Mode 


Additional Clock Cycles 


(An) 





(An)+ 





-(An) 


2 


d16(An) 


5 


d8(An,i) 


7 


addr-1 6-bit 


5 


addr-32-bit 


10 


label 


5 


label(i) 


7 



N For shift instructions, the number of shifts. For move multiple instructions, the number of registers being 

moved. 

The first value is for branch or trap taken, the second is for branch or trap not taken. In the case of Bcc, 
the first of the latter numbers is for a two-byte instruction (8-bit displacement), and the second is for a 
four-byte instruction (16-bit displacement). In the case of DBcc, the first of the latter numbers is for 
branch not taken due to condition true, and the second is for branch not taken due to counter timeout. 

** Indicates maximum value. 

*** The lower value is for condition false (byte set to all ones); the higher value is for condition true (byte 

cleared to all zeroes). 

The following abbreviations are used in Table 7-7: 

a Operand addressing mode (1 bit) 

= data register to data register 

1 = memory to memory 

bbb 3 bits of immediate data. In bit operations the bit numbers - 7. 

bbbbb Bit numbers - 31. 

ccc Shift count 000 = 8 shifts 

001 = 1 shift 

010 = 2 shifts 

011=3 shifts 

100 = 4 shifts 

101 = 5 shifts 
110 = 6 shifts 
111=7 shifts 

ddd Destination register — same coding as rrr. 
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Source effective address (6 bits) 



[EXT] 
ffffff 

gggggg 

hhhhhh 



JJJJJ) 
kkl<k 



PPPP 
qqqq 
rrr 



sss 
t 

WW 

w 

XX 

xxxx 
YY 

YYYY 
zzzz 



Address Mode 


MODE/REGISTER 


(An) 


OlOrrr 


(An)+ 


Oil rrr 


-(An) 


lOOrrr 


d16(An) 


101 rrr 


d8(An,i) 


llOrrr 


addr-1 6-bit 


111000 


addr-32-bit 


111001 


label 


111010 


label(i) 


111011 



[EXT] 



XXXX 

a iii w 000 xx 

PPPP 

PPPP qqqq 

xxxx 

a iii w 000 xx 

One or two optional words of extension addressing that nnaY or may not appear, depending on the 

addressing mode (see the Addressing Modes description). 

Destination effective address — same as eeeeee except no label or label(i). 

Destination effective address but in a format with the MODE and REGISTER fields switched (e.g., 

(An)=rrr010). 

Multiple-destination effective address — same as ffffff except no (An)-(- or —(An).? 

Index register — same coding as rrr. 

Jump effective address — same as eeeeee except no (An)-I- or —(An). 

Register mask list for predecrement mode, in the following format (a "1" selects the register): 

15 14 13 12 11 109 8 7 6 5 4 3 2 1 
DO D1 D2 03 D4 D5 D6 D7 AO A1 A2 A3 A4 A5 A6 A7 
Register mask list for non-predecrement modes, in the format (a "1" selects the register): 

15 14 13 12 11 109 87 6 54 3 2 1 

A7 A6 A5 A4 A3 A2 A1 AO D7 D6 D5 D4 D3 D2 D1 DO 

16-bit address word or most significant word of 32-bit address 
Least significant word of 32-bit address 
Register 000 = DO or AO 

001 = D1 or A1 

010 = D2 or A2 

Oil = D3 or A3 

100 = D4 or A4 

101 = D5 or A5 

110 = D6 or A6 

111 = D7 or A7 

Source register — same coding as rrr 
Type of register = Dn 
1 = An 
4-bit vector 
Index size. = sign extended, low-order integer in index register 

1 = long word value in Index register 
8-bit address displacement 
16-bit address displacement 
8-bit immediate data 

16-bit immediate data or most significant word of 32-bit data 
Least significant word of 32-bit data 



INTERFACING THE MC68000 WITH 6800 PERIPHERALS 

Many peripheral components have been developed by Motorola and other manufacturers for the 8-bit 6800 
microprocessor. In general, any asynchronous peripheral device can be used with the MC68000 with only a small 
amount of external logic needed to meet the interface requirements (handshaking, etc.). However, the 6800-family 
components are based on synchronous read/write operations. This imposes certain constraints when you 
attempt to use a 6800 peripheral device with an asynchronous processor such as the MC68000. Obviously, it was 
in Motorola's interest to design the MC68000 so that it would be able to use both conventional asynchronous devices 
and the family of existing synchronous 6800 devices. Therefore they have included logic to simplify interfacing 6800 
peripheral devices. 
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Again, the MC6 8000 perfo rms read/write operations asynchronously. The signals i nvolved with these operations are 
the strobes (AS, UDS, LDS), the R/W signal, the Data Transfer Acknowledge signal (DTACK), and of course the address 
(A1-A23) and data (D0-D15) signals. 

Three additional signals are used to perform the sy nchro nous read/write operations requ ired by 6800 peripheral 
devices. These signals are Valid Memory Address (VMA), Valid Peripheral Address (VPA), and Enable (E). Figure 
7-29 illustrates the timing of the synchronousjread and write cycles. After the MC68000 has output the address on 
A1-A23 and has asserted the Address Strobe (AS), external logic is expected to decode informati on on the address 
lines. If a 6800 peripheral device is being addressed, then the external logic should assert the VPA input to the 
MC68000. This causes the MC68000 to emulate the data transfer timing of the 6800 microprocessor. As a 
result, the transfer of data is synchronized with the clock signal E. The MC68000 will keep the address outputs 
valid throughout this cycle. 

During a read cycle, the 6800 peripheral device i s expected to place data on the Data Bus when the E signal is high. 
Note that the Data Transfer Acknowledge (DTACK) signal is not used since that signal implies an asynchronous transfer 
of data. Instead, the falling edge of E indicates that the data transfer (either read or write) has been completed. The 
MC68000 then proceeds to complete the cycle in the normal fashion by negating the strobe signals and returning the 
Address Bus to the high impedance state. 

You will note in Figure 7-29 that there is a difference in the total number of CLK cycles for the read and write 
operations. You should not infer from this that all 6800-type read operations take four more CLK cycles than 
write operations. That is only the case in the example shown, and has to do with the phase of E when the read 
or write operation was begun. In general, the E signal and the current MC68000 cycle state will not be synchronized 
at the outset of a 6800 reference cycle. This is because the E signal has a duty cycle of 40%: E is high for four CLK 
periods and low for six CLK periods. The MC68000 instruction cycles, on the other hand, vary in the number of CLK sig- 
nal periods needed to execute. During the write cycle we have shown in Figure 7-29, the E signal is in synchronization 
with the instruction execution cycle. Thus this particular write cycle takes the minim um possible number of CLK cycles 
to execute. Note that the MC68000 automatically inserts wait states after the VPA signal is input. The number of wait 
states inserted will depend on how much time is needed in order to synchronize with the signal. 

The VMA signal is output by the MC68000 in response to the VPA output. 

At the end of th e read or write cycle, the 6800 peripheral device or the address decoding logic in the system must 
negate the VPA signal within one clock period after the MC68000 negates AS. Otherwise, the MC68000 will assume 
that the following cycle is also supposed to be a 6800-type synchronous cycle. 

Figure 7-30 summarizes the timing constraints of 6800 peripherals. It includes the 6800 processor signals for 
reference so you can compare them with those associated with the MC68000. 

A SIMPLE MC68000/6800 INTERFACE EXAMPLE 

Figure 7-31 illustrates a simple interface of two 6800 peripheral devices in an MC68000-based system. In this 
example, the address region OOOOOO^g through 7FFFFFiq (the lower eight megabytes) is used for asynchronous devices 
including memory. The upper eight megabytes is used, albeit inefficiently, for the two synchronous 6800 peripheral 
devices. The PIA (Peripheral Interface Adaptor) is assigned addresses 8OOOOO16 through BFFFFFig, while the ACIA 
(Asynchronous Communications Interface Adaptor) is assigned addresses COOOOO^g through FFFFFFig. 

Interrupt request signals are connected directly to the IPLO and I PL1 input pins of the MC68000. Note that IPL2 
is tied high. In this example, an interrupt from the ACIA causes I PLO to become active thus generating an interrupt of 
level 1 (the lowest priority). Both PIA interrupts are connected to IPL1. When either of these becomes active, an inter- 
rupt of level 2 is generated. If both the ACIA and the PIA request an interrupt simultaneously, an interrupt of level 3 
would be generated. 

For a detailed description of how the MC68000 responds to interrupt requests, refer to our earlier discussion of 
MC68000 exception processing. 

We have also included logic that will cause the MC68000 to use its autovector capability during response to an 
interrupt request from one of the 6800 family devices. Recall that if the VPA signal is asserted to the MC68000 dur- 
ing an interrupt acknowledge cycle, then no byte of vector data need be supplied by the requesting device; instead, the 
MC68000 gets the appropriate autovector from the exception processing vector table. 
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Standard Read Cycle — *4-* 



SO S2 S4 S6 



SO S2 S4 SW SW SW SW SW SW SW SW SW SW S6 



CLK 



JVUVIWAAAAAAAAAAAA. 



A1-A23 



AS 



Dd5/ld§ 



R/W 



-c 



l-C 



DTACK 



D0-D15 



VPA 



VMA 



^ 
^ 



"L^ 



6800 Peripheral Read Cycle- 



WAAAAAAAAiWV 
- < ~l -/ 



r~\ 



< 



Input Data 



A 



J 



•6800 Peripheral Write Cycle - 



SO S2 S4 SW SW SW SW SW SW S6 



SO 



{ 



Output Data 



\ 






> 



I V 

\=. r 



Figure 7-29. MC68000 Synchronous Read/Write Timing for 6800 Peripherals 



MC68000 CLK 



SO S2 S4 SW SW SW SW SW SW SW S6 SO 

~\ I V 



TypeB 

Type A 

Std 



MC6800* 
— 1 50 ns— 
^1 80 ns— 
—270 ns- 



Type B- 
Type A- 



Std ► 



Peripheral* 
70 ns 
140 ns 
160 ns 



MC6800 VMA, 
R/W 



MC6800 Address 



— A U 30 ns MC6800* 

— H U 1 ns Peripheral* 



MC6800 
Read Data 



MC6800 
Write Data 



MC68000 
Address 



z~yw 



a5 



VPA 



VMA 



Write Data 



MC6800 E Clock Freq. 


Type 


2.0 MHz 


B 


1.5 MHz 


A 


1.0 MHz 


Std 



Type B 
Type A 



Peripheral* 
—180 ns— 
—220 ns- 
—320 ns— 



•lOnsMCBBOO* 
♦-10 ns Peripheral 



D 



Peripheral* 



Type B 



-60 ns-^ 
Type A U— 80 ns-^ 
-•-1 95 ns-«< 



MC68000 (8 MHz) 
[-►-187ns-»-j 



Times are given for different MC6800 device clock frequencies 



Figure 7-30. MC68000/6800 Interface Timing Signal Summary 
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+5 V 

o 



AS 
VMA 



D0-D15 
A1-A23 



C 



MC68000 



^■^Oo-<3: 



FCC 
FC1 
FC2 



IPL2 
IPL1 
I PLC 



RESET 

_E 
R/W 



3.3Kft 



s 



I N INTACK 

+5 V 
O 




^K> 



> 



Ico w www 
!o o o oc oc 



6821 PIA 



3.3Kn, 



U-t 






6850 ACIA 



Figure 7-31. A Simple MC680dO/6800 interface Exampie 
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Table 7-4. MC68000 Instructions Which Use Implied Registers 



Instruction 


Implied Register(s) 


Branch Conditional (Bcc), Branch Always (BRA) 


PC 


Branch to Subroutine (BSR) 


PC, SP 


Check Register against Bounds (CHK) 


SSP, SR 


Test Condition, Decrement and Branch (DBcc) 


PC 


Signed Divide (DIVS) 


SSP, SR 


Unsigned Divide (DIVU) 


SSP, SR 


Jump (JMP) 


PC 


Jump to Subroutine (JSR) 


PC, SP 


Link and Allocate (LINK) 


SP 


Move Condition Codes (MOVE CCR) 


SR 


Move Status Register (MOVE SR) 


SR 


Move User Stack Pointer (MOVE USP) 


USP 


Push Effective Address (PEA) 


SP 


Return from Exception (RTE) 


PC, SP, SR 


Return and Restore Condition Codes (RTR) 


PC, SP, SR 


Return from Subroutine (RTS) 


PC, SP 


Trap (TRAP) 


SSP, SR 


Trap on Overflow (TRAPV) 


SSP, SR 


Unlink (UNLK) 


SP 
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Table 7-5. MC68000 Instructions Which Use Implied Registers 



Primary 
Mnemonic 


Alternate 
Mnemonic 


Operand 


Description 


ADD. B 


ADDI. B 


dataS.xx 


Add Immediate Byte 


ADD.W 


ADD 


xx,xx 


Add Word 




ADDA.W 


xx,An 


Add Address Register Word 




ADDI. W 


data16,xx 


Add Immediate Word 


ADD. L 


ADDA.L 


xx.An 


Add Address Register Long 




ADDI.L 


data32,xx 


Add Immediate Long 


ADDQ.B 


ADD.B 


data3,xx 


Add Quick Byte 


ADDQ.W 


ADD 
ADD.W 


dataS.xx 


Add Quick Word 


ADDQ.L 


ADD. L 


dataS.xx 


Add Quick Long 


AND.B 


ANDI.B 


dataS.xx 


AND Immediate Byte 


AND.W 


AND 


xx.xx 


AND Word 




ANDI.W 


data16,xx 


AND Immediate Word 


AND.L 


ANDI.L 


dataS2,xx 


AND Immediate Long 


Bcc 


Bcc.S 


XX 


Conditional Branch Short 


CLR.W 


CLR 


XX 


Clear Word 


CMP.B 


CMPI.B 


dataS.xx 


Compare Immediate Byte 


CMP.W 


CMP 


XX.XX 


Compare Word 




CMPA.W 


xx.An 


Compare Address Register Word 




CMPI.W 


data16,xx 


Compare Immediate Word 


CMP. L 


CMPA.L 


xx.An 


Compare Address Register Long 




CMPI.L 


dataS2,xx 


Compare Immediate Long 


EOR.B 


EORI. B 


dataS.xx 


Exclusive OR Immediate Byte 


EOR.W 


EOR 


xx.xx 


Exclusive OR Word 




EORI. W 


datalB.xx 


Exclusive OR Immediate Word 


EOR. L 


EORI. L 


data32,xx 


Exclusive OR Immediate Long 


MOVE. W 


MOVE 


xx.xx 


Move Word 




MOVEA. W 


xx.An 


Move Address Register Word 


MOVE. L 


MOVEA.L 


xx.An 


Move Address Register Long 


MOVEQ 


MOVE. L 


dataS.xx 


Move Quick (always Long) 


OR. B 


ORI. B 


dataS.xx 


OR Immediate Byte 


OR. W 


OR 


xx.xx 


OR Word 




ORI.W 


data16.xx 


OR Immediate Word 


OR. L 


ORI. L 


data32,xx 


OR Immediate Long 


SUB.B 


SUBI. B 


dataS.xx 


Subtract Immediate Byte 


SUB.W 


SUB. 


xx.xx 


Subtract Word 




SUBA. W 


xx.An 


Subtract Address Register Word 




SUBI.W 


data16.xx 


Subtract Immediate Word 


SUB.L 


SUBA. L 


xx.An 


Subtract Address Register Long 




SUBI. L 


data32.xx 


Subtract Immediate Long 


SUBQ. B 


SUB.B 


dataS.xx 


Subtract Quick Byte 


SUBO. W 


SUB 
SUB.W 


dataS.xx 


Subtract Quick Word 


SUBQ.L 


SUB.L 


dataS.xx 


Subtract Quick Long 
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Table 7-6. MC68000 Instruction Set Summary 













Status 






Mnemonic 


Operand (s) 


Bytes 


Clock 




Operation Performed 




Cycles 


























T 


S 


X 


N 


z 


V 


c 






LEA 


jadr.An 


2,4, 
or 6 


2(0/0)+ 
















[An] — jadr 
Load effective address into specified address register. The addressing 
size Is long, although the address loaded may be byte, word, or long, 
depending on how It is subsequently used.^ 




MOVE.B 


(An),Dn \ 


2 


8(2/0) 








X 


X 








[Dn<0-7>] -[[An]] 
Register indirect 






(An) +,Dn 


2 


8(2/0) 








X 


X 








[Dn<0-7>] - [[Anil, [An] - [Anl + 1 
Register Indirect with postincrement^ 






-(An),Dn 


2 


10(2/0) 








X 


X 








[An] *- [An] - 1, [Dn<0-7>] — [[An]] 
Register Indirect with predecrementi 






d16(An),Dn \ 


4 


12(3/0) 








X 


X 








[Dn<0-7>] -[[An] + d161 






> sadr 




















Register indirect with displacement 






d8(An,i),Dn 1 


4 


14(3/0) 








X 


X 








[Dn<0-7>] -[[An] + d8 + [ill 
Register indirect, indexed 


o 




addr.Dn I 


4 or 6 


4(1/0)+ 








X 


X 








[Dn<0-7>] — [addrl 


u 




1 




















Direct address 


3 
O. 




label,Dn 1 


4 


12(3/0) 








X 


X 








[Dn<0-7>]-[[PC] + d16] 


I 




I 




















Program relative 


3 




label (i),Dn / 


4 


14(3/0) 
















[Dn<0-7>] -[[PC] +d8+ [ill 


























Program relative, indexed 


3 
























Load byte to data register from memory location specified by any of 


(D 
























the addressing modes above. Bits 8-31 of the data register are not 


s 
























affected. 


s 


IVIOVE.B 


Dn(An) v 


2 


9(1/1) 








X 


X 








[[An]] -[Dn<0-7>1 


(D 




\ 




















Register indirect 


i 




Dn,(An)+ 1 


2 


9(1/1) 








X 


X 








[[An]] - [Dn<0-7>], [Anl - [Anl + 1 


3 

2 




1 




















Register indirect with postincrement^ 


(D 




Dn,-(An) 1 

y dadr 


2 


9(1/1) 








X 


X 








[Anl - [Anl - 1, ([Anil - [Dn<0-7>1 
Register indirect with predecrement^ 






Dn,d16(An) / 


4 


13(2/1) 








X 


X 








[[An] +d16] — [Dn<0-7>1 
Register Indirect with displacement 






Dn,d8(An, i) 1 


4 


15(2/1) 








X 


X 








[[An] +d8+ [ill -[Dn<0-7>1 
Register Indirect, indexed 






Dn.addr ^ 


4 or 6 


5(0/1)+ 








X 


X 








[addrl — [Dn<0-7>1 
Direct address 

Store byte from data register to memory location specified by any of 
the addressing modes above. 




IVIOVE.B 


sadr.dadr 


2,4 
6,8 
or 10 


5(1/1)+ 








X 


X 








Idadr) — [sadr] 
Store byte from specified source memory location to specified 
destination memory location.'' 


Notes: 








1 . Postincrement and predecrement change by 1 , unles 


5 the addres 


s register specified is the Stack Pointer (A 7), where the address is changed by 2 rather than 1 to keep the Stack Pointer | 


on a word boundary. 








2. The effective address must be on an even word bou 


ndary (000 


0, 0002, 0004, etc.). 




3. Postincrement and predecrement change by 2. 








4. Postincrement and predecrement change by 4. 









Table 7-6. MC68000 Instruction Set Sumnnary (Continued) 





Mnemonic 


Operand (s) 


Bytes 


Clock 
Cycles 


Status 


Operation Performed 


T 


S 


X 


N 


z 


V 


c 




MOVE.W 


sadr, Dn 


2.4 
or 6 


4{1/0)+ 








X 


X 








(Dn<0-15>l — [sadr] 
Load word to data register from memory location. Bits 16-31 of the 
data register are not affected.^' ^ 




MOVE.W 


sadr.An 


2.4 
ore 


4(1/0+ 
















[Anl<0-15>] 

[An < 16-31 >] — [An<15>l 

Load word to address register from memory location. The sign is 

extended to all upper bits of the register. 2, 3 




MOVE.W 


rs.dadr 


2.4 
ore 


S(0/1)+ 








X 


X 








[dadr] — [rs<0-15>] 
Store word to memory location from data or address register.2, 3 




MOVE.W 


sadr.dadr 


2,4 
6,8 
or 10 


5(0/1)+ 








X 


X 








[dadr] - [sadr] 
Store word from source memory location to destination memory loca- 
tion.2- 3 




MOVE.L 


sadr.Dn 


2,4 
or e 


4(1/0)+ 








X 


X 








[Dn<0-31>1 -[sadr] 
Load long word to data register from memory location.^, 3 


o 


MOVE.L 


sadr.An 


2.4 
or 6 


8(2/0+ 
















[An<0-31>1 -[sadr] 
Load long word to address register from memory location.2- 4 


a. 


MOVE.L 


rs.dadr 


2.4 
or 6 


10(0/2)+ 








X 


X 








[dadr] — [rs<0-31>] 
Store long word from data or address register to memory location. 2. 4 


i 


MOVE.L 


sadr.dadr 


2.4 
6,8 
or 10 


14(1/2)+ 








X 


X 








[dadr] — [sadr] 
Store long word from source memory location to destination memory 
locatlon.2, ■* 


s 

a 
3 

o 

3) 

2, 


MOVEM.W 


jadr,reg-iist 


4, 6 
or 8 


8 + 4n(2 + n/0+ 
















(regi<0-15>] — [[Anil, [regi <16-31 >] — [regi<15>] 
[reg2<0-15>] — [(An + 2]).[reg2< 16-31 >] — [reg2<15>] 
(reg3<0-15>] - [[An + 4]].[reg3< 16-31 >] ^ [reg3<15>l 


5 
3 

3 
O 

a 

O 

o 

3 
























[regn<0-15>] - [[An + 2n-2)]],[regn<16-31 >] - [regn<15>] 
Load multiple words from sequential memory locations to specified 
registers, in order D0-D7. A0-A7. The sign is extended to all upper bits 
of the register.2 


C 
1 


MOVEM.W 


(An)+.reg-list 


4 


8 + 4n(2 + n/0) 
















[regi<0-15>] - [[An]].(regi < 16-31 >] - [regi <15>],[An] ^ 

[An + 21 
[reg2<0-15>] — [[An]].(reg2< 16-31 >] — [reg2<15>],[Anl — 

[An + 2] 
[reg3<0-15>] - [[An]].[reg3< 16-31 >1 - [reg3<15>], [An] - 

[An + 2] 

[regn<0-15>] - [[An]], [reg,, < 16-31 >] - [regn<15>].[An] - 
[An + 2] 
Same as above except with postincrement.3 



Table 7-6, MC68000 Instruction Set Sunrimary (Continued) 





Mnemonic 


Operand (s) 


Bytes 


Clock 
Cycles 


Status 


Operation Performed 


T 


S 


X 


N 


Z 


V 


c 




MOVEM.W 


reg-list,madr 


4,6 
or 8 


4 + 5n(1/n)+ 
















[[An]] -[regi<0-15>] 
[(An + 2]] - [reg2<0-15>] 
[[An + 41] - [reg3<0-15>l 

[(An + (2n-2)] - [regn<0-15>] 
Store multiple words to sequential memory locations from specified 
registers, in order D0-D7, A0-A7.2 




MOVEM.W 


reg-list,-(An) 


4 


4+ 5n(1/n) + 
















[An] - [An-2],[[An]] ^ [regn<0-15>l 


o 

0) 

3 
O. 
























[An] - [An-2],[[An]l - [reg3<0-15>] 

[An] - [An-2],[[An]l - [reg2<0-15>] 

[An] - [An-2],[[Anl] ~- [regi <0-15>] 
Store multiple words to sequential memory locations with predecre- 
ment to specified registers, in order A7-A0, D7-D0.2. 3 


5 

1' 


MOVEM.L 


jadr.reg-list 


4,6 
or 8 

4 
4,6 
or 8 

4 


8 + 8n(2 + 2n/0) 
















\ 


< 

s 




(An)+,reg-list 
reg-listmadr 


8 + 8n(2 + 2n/0) 
4+ 10n(1/n) + 
















{ Same as MOVEM.W except that all 32 bits of the registers are 
/ moved.2. ^ 


3 

o 




reg-list,-(An) 


4+ lOnd/n) 
















) 


■< 

« 
ffl 
3 

3 
O 


MOVER. W 


d16(An),Dn 


4 


16(4/0) 
















[Dn<8-15>l ^ [[An] + d16],[Anl — [An] + 2 
[Dn<0-7>] — [[An] + d16l 

Load peripheral data bytes from alternate memory locations to data 

register word. The address is a byte address.3 


5' 
c 


MOVEP.W 


Dn,d16(An) 


4 


18(2/2) 
















[[An] + d16] — [Dn<8-15>],[An] '- [An] + 2 
[[An] +d16] — [Dn<0-7>] 

Store peripheral data bytes from data register long to alternate 

memory locations. The address is a byte address.^ 


a 


MOVEP.L 
MOVEP.L 


dos(An),Dn 

Dn,d16(An) 


4 
4 


24(6/0) 
28(2/4) 
















[Dn<24-31 » ^ [[An] + d16],[An] - [An] + 2 
[Dn<16-23>] ~- [[An] + d16],[An] — [An] + 2 
[Dn<8-15>] ^ [[An] + d16],[An] — [An] + 2 
[Dn<0-7>] — [[An] + d161 

Load peripheral data bytes from alternate memory locations to data 

register long. The address is a byte address.^ 
[[An] + d16] — [Dn<24-31 >],[An] — [An] + 2 
[lAnl + d16] ^ [Dn<16-23>],[An] ^[An] + 2 
[[An] + d16] - [Dn<8-15>],[Anl - [An] + 2 
[[An] + d16] — [Dn<0-7>1 

Store peripheral data bytes from data register long to alternate 

memory locations. The address is a byte address.3 



Table 7-6. MC68000 Instruction Set Summary (Continued) 





Mnemonic 


Operand(s) 


Bytes 


Clock 
Cycles 


Statu 


5 






Operation Performed 


T 


S 


X 


N 


z 


V 


c 




ABCD 


-(sAn),-(dAn) 


2 


19(3/1) 






X 


u 


X 


u 


X 


[sAn] — (sAnl - 1 

[dAn] -[dAnl-1 

[(dAnll - [[dAnll + [[sAnll + X 

Add decimal memory byte to memory byte with carry (Extend bit). 

Both addresses are byteV 




ADD.B 


sadr.Dn 


2.4 
or 6 


4(1/0)+ 






X 


X 


X 


X 


X 


[Dn<0-7>] — [Dn<0-7>1 + [sadrl 
Add byte to data register from memory location. Bits 8-31 of the data 
register are not affected. ^ 




ADD.B 


Dn.dadr 


2.4 
or 6 


9(1/1)+ 






X 


X 


X 


X 


X 


[dadrl ^ [dadr] + [Dn<0-7>1 
Add byte to memory location from data register. ^ 




ADD.W 


sadr.Dn 


2.4 
or 6 


4(1/0)+ 






X 


X 


X 


X 


X 


[Dn<0-15>l ^ (Dn<0-15>l + [sadr) 
Add word to data register from memory location. Bits 16-31 of the 
data register are not affected.2, 3 


(0 

a 
o 

s 


ADD.W 


sadr.An 


2.4 
or 6 


8(1/0) + 
















[An<0-31 >1 — [An<0-31 >1 + [sadr] (sign extended) 
Add word to address register from memory location. The sign of the 
memory word is extended to a full 32 bits for the operation.2. 3 


Q. 
0) 

•< 


ADD.W 


Dn.Dadr 


2.4 
or 6 


9(1/1)+ 






X 


X 


X 


X 


X 


[dadrl — [dadrl + [Dn<0-15>] 
Add word to memory location from data register.2. 3 


s 


ADD.L 


sadr.Dn 


2,4 
or 6 


6(1/0)+ 






X 


X 


X 


X 


X 


[Dn<0-31 >1 — [Dn<0-31 >1 + [sadr] 
Add long word to data registers from memory location.2, * 


■< 
a 


ADD.L 


sadr.An 


2.4 
or 6 


6(1/0)+ 
















[An<0-31>] — [An<0-31>] + [sadr] 
Add long word to address register from memory location.^. * 


f 

3 


ADD.L 


Dn.dadr 


2,4 
or 6 


14(1/2)+ 






X 


X 


X 


X 


X 


[dadr] ~- [dadr] + (Dn<0-31 >] 
Add long word to meTnory locations from data register.2. 4 


O 

3 
o 
3 
o 
■< 
o 


ADDX.B 


-(sAn).-dAn) 


2 


19(3/1) 






X 


X 


X 


X 


X 


[sAnl - [sAn] - 1 
[dAn] — [dAnl - 1 
[[dAnll - [[dAnll + [[sAnll + X 

Add memory byte to memory byte with carry (Extend bit). Both 

addresses are byte.^ 


1 


ADDX.W 


-(sAn),-(dAn) 


2 


19(3/1) 






X 


X 


X 


X 


X 


[sAnl - [sAnl - 2 
(dAnl - [dAnl - 2 
((dAnll - [[dAnll + ((sAnll + X 

Add memory word to memory word with carry (Extend bit). Both 

address are word.2. 3 




ADDX.L 


-(sAn).-(dAn) 


2 


32(5/2) 






X 


X 


X 


X 


X 


[sAnl — [sAnl - 4 
[dAnl - [dAnl - 4 
[[dAnll - [[dAnll + [[sAnll + X 

Add memory long word to memory long word with carry (Extend bit). 

Both addresses are long word.2' 4 




AND.B 


sadr.Dn 


2.4 
or 6 


4(1/0)+ 








X 


X 








[Dn<0-7>1 — [Dn<0-7>1 < [sadrl 
AND byte to data register from memory location. Bits 8-31 of the data 
register are not affected.'' 




AND.B 


Dn.dadr 


2,4 
or 6 


9(1/1)+ 








X 


X 








[dadr] -[dadrl < (Dn<0-7>1 
AND byte to memory location from data register. 1 



Table 7-6. MC68000 Instruction Set Summary (Continued) 













Status 


^^■■^ 


^^^ 






Mnemonic 


Operand(s) 


Bytes 


Clock 
Cycles 










Operation Performed 


T 


S 


X 


N 


z 


V 


c 




AND.W 


sadr.Dn 


2.4 
ore 


4(1/0)+ 








X 


X 








(Dn<0-15>l — [Dn<0-15>] A [sadr] 
AND word to data register from memory location. Bits 16-31 of the 
data register are not affected.2. 3 




AND.W 


Dn.dadr 


2.4 
or 6 


9(1/1)+ 








X 


X 








[dadr] - [dadr] < lDn<0-15>] 
AND word to memory location from data register.2, 3 




AND.L 


sadr.Dn 


2.4 
or 6 


6(1/0)+ 








X 


X 








[Dn<0-31>] — [Dn<0-31>] A [sadr] 
AND long word to data register from memory location.2. 4 




AND.L 


Dn.dadr 


2.4 
or 6 


14(1/2)+ 








X 


X 








[dadr] — [dadr] < [Dn<0-31>] 
AND long word to memory location from data register.2. 4 




CLR.B 


dadr 


2.4 
or 6 


9(1/1)+ 











1 








[dadr] — 
Clear memory byte to zeroes.^ 




CLR.W 


dadr 


2.4 


9(1/1)+ 











1 








[dadr] - 


CO 

9 






or 6 


















Clear memory word to zeroes. 2. 3 


O 

o 


CLR.L 


dadr 


2.4 


14(1/2)+ 











1 








[dadr] — 


3 
O. 
0} 






or 6 


















Clear memory long word to zeroes. 2- 4 


< 


CMP.B 


sadr.Dn 


2.4 


4(1/0)+ 








X 


X 


X 


X 


[Dn<0-7>] - [sadr] 


s 






or 6 


















Compare data register byte with memory byte and set condition codes 


i 
























accordingly. Register/memory data are not changed on any com- 


o 

.5 , 
























pares.! 


39 


CMP.W 


sadr.Dn 


2,4 


4(1/0)+ 








X 


X 


X 


X 


[Dn<0-15>] - [sadr] 








or 6 


















Compare data register word with memory word and set condition 


i 
























codes accordingly.2. 3 


8 


CMP.W 


sadr.An 


2.4 


6(1/0)+ 








X 


X 


X 


X 


[An<0-15>l - [sadr] 


s 

o 






or 6 


















Compare address register word with memory word and set condition 
























codes accordingly.2. 3 


CMP.L 


sadr.Dn 


2.4 


6(1/0)+ 








X 


X 


X 


X 


[Dn<0-31>1 - [sadr] 


■< 






or 6 


















Compare data register with memory long word and set condition 


§ 
























codes accordingly.2' 4 




CMP.L 


sadr.An 


2.4 


6(1/0+ 








X 


X 


X 


X 


[An<0-31>] - [sadr] 


s 






ore 


















Compare address register with memory long word and set condition 


o 
























codes accordingly.2. 4 


o 

3 


CMPM.B 


(sAn)+,(dAn)+ 


2 


12(3/0) 








X 


X 


X 


X 


[[dAn]] - [[sAn]] ' 


5' 
























[dAn] - [dAn] + 1 


c 
























[sAn] — [sAn] + 1 


& 
























Compare memory bytes and set condition codes accordingly. The 
memory data are not changed on any compares.'' 




CMPM.W 


(sAn)+,(dAn)+ 


2 


12(3/0) 








X 


X 


X 


X 


[[dAn]] - [[sAn]] 
[dAn] - [dAn] + 2 
[sAn] — [sAn] + 2 
Compare memory words and set condition codes accordingly.2. 3 




CMPM.L 


(sAn)+.(dAn)+ 


2 


20(5/0) 








X 


X 


X 


X 


[[dAn]] - [[sAn]] 
[dAn] - [dAn] + 4 
[sAn] ^ [sAn] + 4 
Compare memory long words and set condition codes accordlngly.2. 4 



Table 7-6. MC68000 Instruction Set Summary (Continued) 













Status 


^■■^ 








Mnemonic 


Operand (s) 


Bytes 


Clock 
Cycles 










Operation Performed 


T 


S 


X 


N 


z 


V 


c 




DIVS 


sadr.Dn 


2.4 
or 6 


< 158(1/0)+ 








X 


X 


X 





[Dn<0-15>] — [Dn<0-31>] + [sadr] 
[Dn<16-31>] —remainder 

Divide signed numbers. Division by zero causes a TRAP. The source 

address is a word address. 2, 3 




DIVU 


sadr.Dn 


2,4 
or 6 


^140(1/0+ 








X 


X 


X 





[Dn<0-15>l — [Dn<0-31>] ^ [sadr] 
[Dn<16-31>] —remainder 

Divide unsigned numbers. Division by zero causes a TRAP. The source 

address is a word address.^- 3 




EOR.B 


Dn.dadr 


2.4 
or 6 


9(1/1)+ 








X 


X 








[dadr] — [dadr] V [Dn<0-7>] 
Exclusive-OR byte to memory location from data register.1 




EOR.W 


Dn.dadr 


2,4 
or 6 


9(1/1)+ 








X 


X 








[dadr] — [dadr] V (Dn<0-15>] 
Exclusive-OR word to memory location from data registers.^. 3 


CO 


EOR.L 


Dn.dadr 


2.4 


14(1/2)+ 








X 


X 








[dadr] -[dadr] V[Dn<0-31>] 


o 

o 






or 6 


















Exclusive-OR long word to memory location from data register. 2, 4 


1 


MULS 


sadr.Dn 


2.4 


< 70(1/0)+ 








X 


X 








[Dn<0-31>] — [Dn<0-15>] x [sadr] 


< 






or 6 


















Multiply two 16-bit signed numbers, yielding a 32-bit signed product. 


1 
























The source address is a word address.2. 3 


i 


MULU 


sadr.Dn 


2.4 


< 74(2/0)+ 








X 


X 








[Dn<0-31>] — [Dn<0-15>] x [sadr] 


9 

•< 






or 6 


















Multiply two 16-bit unsigned numbers, yielding a 32-bit unsigned pro- 


3) 
























duct. The source address is a word address.2. 3 


9 


NBCD 


dadr 


2.4 


9(1/1) + 






X 


u 


X 


u 


X 


[dadr] — - [dadr] - X 


a 

3 






or 6 


















Negate decimal memory byte. This operation produces the tens com- 


























plement if X = or the nines complement if X = 1. 


s 


NEG.B 


dadr 


2,4 


9(1/1) + 






X 


X 


X 


X 


X 


[dadr] — - [dadr] 








or 6 


















Negate memory byte.^ 


o 


NEG.W 


dadr 


2,4 


9(1/1)+ 






X 


X 


X 


X 


X 


[dadr] — - [dadr] 


■< 

o 






or 6 


















Negate memory word.2. 3 


a 


NEG.L 


dadr 


2,4 


14(1/2)+ 






X 


X 


X 


X 


X 


[dadr] — - [dadr] 


a 






or 6 


















Negate memory long word. 2. 4 


«^ 


NEGX.B 


dadr 


2,4 


9(1/1)+ 






X 


X 


X 


X 


X 


[dadr] — - [dadr] - X 


? 






or 6 


















Negate memory byte with Extend bit.'' 


3 


NEGX.W 


dadr 


2.4 


9(1/1) + 






X 


X 


X 


X 


X 


[dadr] — - [dadr] - X 


3 
C 






or 6 


















Negate memory word with Extend bit.2. 3 


a 


NEGX.L 


dadr 


2.4 
or 6 


14(1/2)+ 






X 


X 


X 


X 


X 


[dadr] — - [dadr] - X 
Negate memory long word with Extend bit.2, 4 




NOT.B 


dadr 


2.4 
or 6 


9(1/1)+ 








X 


X 








[dadr] - (dadrl 
Ones complement memory byte.^ 




NOT.W 


dadr 


2.4 
or 6 


9(1/1) + 








X 


X 








[dadr] — [dad?] 
Ones complement memory word. 2, 3 




NOT.L 


dadr 


2.4 
or 6 


14(1/2)+ 








X 


X 








[dadr] — [dadr] 
Ones complement memory long word.2, 4 




ORB 


sadr.Dn 


2.4 
or 6 


4(1/0)+ 








X 


X 








[Dn<0-7>] - [Dn<0-7>] V [sadrl 
OR byte to data register from memory location. Bits 8-31 of the data 
register are not affected. ^ 




ORB 


Dn.dadr 


2,4 
or 6 


9(1/1)+ 








X 


X 








[dadr] — [dadr] V [Dn<0-7>] 
OR byte to memory location from data register.^ 



Table 7-6. MC68000 Instruction Set Summary (Continued) 





Mnemonic 


Operand(s) 


Bytes 


Clock 
Cycles 


Status 


Operation Performed 


T 


S 


X 


N 


z 


V 


c 




OR.W 


sadr.Dn 


Z4 
ore 


4(1/0+ 








X 


X 








[Dn<0-15>l — [Dn<0-15>] V [sadr] 
OR word to data register from memory location. Bits 16-31 of the data 
register are not affected.2, 3 




OR.W 


Dn.dadr 


2.4 
ore 


9(1/1)+ 








X 


X 








[dadr! ^ [dadr] < [Dn<0-15>] 
OR word to memory location from data register.2. 3 




OR.L 


sadr,Dn 


2.4 
ore 


6(1/0)+ 








X 


X 








[Dn<0-31>] — [Dn<0-31>] V [sadr] 
OR long word to data register from memory location.2, 4 




ORL 


Dn.dadr 


2,4 
ore 


14(1/2)+ 








X 


X 








[dadr] — [dadr] < [DnVO-31 >] 
OR long word to memory location from data register.2, 4 




SBCD 


-(sAn),-(dAn) 


2 


19(3/1) 






X 


u 


X 


u 


X 


[sAn] ~- [sAn] - 1 
IdAnl ^ [dAn] - 1 
[[dAn]) - [[dAn]] - [[sAn]] - X 


to 
























Subtract decimal memory byte from memory byte with carry (Extend 


(« 
o 
























bit). Both addresses are byte.^ 


3 


sec 


dadr 


2,4 


9(1/1)+ 
















[dadr] — [all 1'sif cc = TRUE 


a 






or e 


















[dadr] — all O's if cc = FALSE 


•< 

s 
























Set status in memory byte.^ 


1 


SUB.B 


sadr.Dn 


2.4 


4(1/0+ 






X 


X 


X 


X 


X 


[Dn<0-7>] ^ [Dn<0-7>] - [sadr] 






or e 


















Subtract memory byte from byte in data register. Bits 8-31 of the data 


























register are not affected. ^ 


? 


SUB.B 


Dn.dadr 


2,4 


9(1/1)+ 






X 


X 


X 


X 


X 


[dadr] — [dadr] - [Dn<0-7>] 


if 
a 






ore 


















Subtract byte in data register from memory byte.1 


3 
O 


SUB.W 


sadr.Dn 


2,4 


4(1/0)+ 






X 


X 


X 


X 


X 


[Dn<0-15>] — [Dn<0-15>] - [sadr] 


(S 






ore 


















Subtract memory word from word in data register. Bits 16-31 of the 


f 
























data register are not affected.2. 3 


3 
o 


SUB.W 


sadr.An 


2.4 


8(1/0+ 






X 


X 


X 


X 


X 


[An<0-31 >] — [An<0-31 >] - [sadr] (sign extended) 


5 






ore 


















Subtract memory word from address register contents. The sign of the 


o 
























memory word is extended to a full 32 bits for the operation. 2. 3 


(D 


SUB.W 


Dn.dadr 


2.4 


9(1/1)+ 






X 


X 


X 


X 


X 


[dadr] — [dadr] - [Dn<015>l 


1 






ore 


















Subtract data register word from memory location word. 2. 3 


o 


SUB.L 


sadr.Dn 


2.4 


6(1/0+ 






X 


X 


X 


X 


X 


[Dn<0-31>] — [Dn<0-31>] - [sadr] 


o 

3 






or 6 


















Subtract memory long word from data register contents.2. 4 


5' 


SUB.L 


sadr.An 


2.4 


6(1/0+ 






X 


X 


X 


X 


X 


[An<0-31>] ^ [An<0-31>] - [sadr] 


c 
a 

a. 






or 6 


















Subtract memory long word from address register contents.2. 4 




SUB.L 


Dn.dadr 


2,4 
or e 


14(1/2)+ 






X 


X 


X 


X 


X 


[dadr] — [dadr] - [Dn<0-31 >] 
Subtract contents of data register from memory long word.2. 4 




SUBX.B 


-(sAn),-(dAn) 


2 


19(3/1) 






X 


X 


X 


X 


X 


[sAn] — [sAnl - 1 
[dAn] - [dAnl - 1 
[[dAnl] - [[dAnl] - [[sAnl] - X 

Subtract memory byte from memory byte with borrow (Extend bit). 

Both addresses are byte.^ 




SUBX.W 


-(sAn).-(dAn) 


2 


19(3/1) 






X 


X 


X 


X 


X 


[sAnj — [sAn] - 2 
[dAn] — [dAnl - 2 
[[dAn]] - [[dAnll - [[sAnl] - X 

Subtract memory word from memory word with borrow (Extend bit). 

Both addresses are word.2. 3 



Table 7-6. MC68000 Instruction Set Sunnmary (Continued) 





Mnemonic 


Operand(s) 


Bytes 


Clock 
Cycles 


Status 


Operation Performed 


T 


S 


X 


N 


z 


V 


c 


o 

u 

3 
Q. 

3 0) 

5' ■< 
% 3 
S| 

o 
< 

3] 

iS, 

o 

3 
O 

a 


SUBX.L 

TAS 
TST.B 
TST.W 
TST.L 


-(sAn),-(dAn) 

dadr 
dadr 
dadr 
dadr 


2 

2,4 
ore 
2.4 
ore 
2,4 
ore 
2,4 
or 6 


32(5/2) 

11(1/1) + 
4(1/0)+ 
4(1/0)+ 
4(1/0)+ 






X 


X 

X 
X 
X 
X 


X 

X 
X 
X 
X 


X 







X 







[sAnl — [sAn] - 4 
[dAn] ^ [dAnl - 4 
[[dAnll - [[dAn]] - [[sAn]] - X 

Subtract memory long word from memory long word with borrow 

(Extend bit). Both addresses are long word.2. 4 
[dadr<7>] — 1 

Test status of memory byte and set high-order bit to 1 . 
[dadr] - 

Test status of memory byte. The byte value is not changed, 
[dadr] - 

Test status of memory word. The word value Is not changed, 
[dadr] - 

Test status of memory long word. The long word value Is not changed. 


3 
3 


MOVEQ 

MOVE.B 

MOVE.B 
MOVE.W 

MOVE.W 

MOVE.W 
MOVE.L 
MOVE.L 
MOVE.L 


dataB.Dn 

dataS.Dn 

dataS.dadr 
data16,Dn 

data16,An 

dataie.dadr 
data32,Dn 
data32,An 
data32,dadr 


2 

4 

4,6 

or 8 

4 

4 

4, e 

ore 

6 

6 

e. 8 

or 10 


4(1/0) 

8(2/0) 

9(1/1) + 
8(2/0) 

8(2/0) 

9(1/1) + 
12(3/0) 
1 2(3/0) 
18(2/2)+ 








X 

X 

X 
X 

X 
X 

X 


X 

X 

X 
X 

X 
X 

X 




























[Dn<0-7>] — dataS 
[Dn<8-32>] ^ [Dn<7>] 

Load immediate data byte to data register. The sign is extended to all 

upper bits of the data register. 
[Dn<0-7>] — dataS 

Load immediate data byte to data register. Bits 8-31 of the data 

register are not affected. 

[dadr] — [dataS] 
Load immediate data byte into memory location. 1 

[Dn<0-15>] — dataie 

Load immediate data word to data register. Bits 16-31 of the data 

register are not affected. 
[An<0-15>] -dataia 
[An < 16-31 >1 — [An<15>] 

Load immediate data word to address register. The sign is extended to 

all upper bits of the register. 

[dadr] — data 16 

Load immediate data word into memory location. 2. 3 
[Dn<0-31>] — data32 

Load immediate data long word Into data register. 
[An<0-31>1 — data32 

Load immediate data long word into address register, 
[dadr] — data32 

Load immediate data long word into memory location.2. 4 


3 

3 
a 
a. 

a 

O 

■a 

3 

a 


ADD.B 

ADD.B 
ADD.W 


dataS.Dn 

dataS.dadr 
dataie.Dn 


4 

4,6 
or 8 

4 


8(2/0) 

13(2/1)+ 
8(2/0) 






X 

X 
X 


X 

X 
X 


X 

X 
X 


X 

X 
X 


X 

X 
X 


[Dn<0-7>] — [Dn<0-7>] + dataS 

Add immediate data byte to data register. Bits 8-31 of the data register 

are not affected, 
[dadr] — [dadr] + dataS 

Add immediate data byte to memory location. 1 
(Dn<0-15>] — [Dn<0-15>] + data16 

Add immediate data word to data register. Bits 16-31 of the data 

register are not affected. 



Table 7-6. MC68000 Instruction Set Summary (Continued) 





Mnemonic 


Operand (s) 


Bytes 


Clock 
Cycles 


Status 


Operation Performed 


T 


S 


X 


N 


z 


V 


c 




ADD.W 


data16,An 


4 


8(2/0) 
















[An<0-31 >] — [An<0-31 >] + data 16 (sign extended) 
Add immediate data word to address register. "The sign of the data 
word is extended to a full 32 bits for the operation. 




ADD.W 


data16.dadr 


4.6 
or 8 


13(2/1)+ 






X 


X 


X 


X 


X 


[dadr] — [dadr] + data 16 
Add immediate data word to memory location.2. 3 




ADD.L 


data32,Dn 


6 


16(3/0) 






X 


X 


X 


X 


X 


[Dn<0-31 >1 — [Dn<0-31 >] + data32 
Add immediate data long word to data register. 




ADD.L 


data32,An 


6 


16(3/0) 
















[An<0-31 >] — [An<0-31 >] + data32 
Add immediate data long word to address register. 




ADD.L 


data32.dadr 


6.8 
or 10 


22(3/2)+ 






X 


X 


X 


X 


X 


[dadr] — [dadr] + data32 
Add immediate data long word to memory location. 2. 4 




ADDae 


dataS.Dn 


2 


4(1/0) 






X 


X 


X 


X 


X 


[Dn<0-7>] — (Dn<0-7>] + dataS 
Add immediate three bits to data register byte. Bits 8-31 of the data 
register are not affected. 




ADoae 


dataS.dadr 


2.4 

ore 


9(1/0)+ 






X 


X 


X 


X 


X 


[dadr] — [dadr] + data3 
Add immediate three bits to memory byte.^ 


3 


ADoaw 


data3,Dn 


2 


4(1/0) 






X 


X 


X 


X 


X 


[Dn<0-15>] — [Dn<0-15>] + data3 
Add immediate three bits to data register word. Bits 1 6-31 of the data 
register are not affected. 


1 

o 
■a 


ADDaW 


data3,An 


2 


4(1/0) 
















[An<0-15>] — [An<0-15>] + data3 
Add immediate three bits to address register word. Bits 16-31 of the 
address register are not affected. 


s 


ADoaw 


data3.dadr 


2.4 
or 6 


9(1/1)+ 






X 


X 


X 


X 


X 


[dadr] ~- [dadr] + data3 
Add immediate three bits to memory word.2. 3 


9 

3 


ADOaL 


data3,Dn 


2 


8(1/0) 






X 


X 


X 


X 


X 


[Dn<0-31>] ^ [Dn<0-31>] + data3 
Add immediate three bits to data register long word. 


3 
C 

a 

a. 


ADDaL 


data3,An 


2 


8(1/0) 
















[An<0-31>1 — [An<0-31>1 + data3 
Add immediate three bits to address register long word. 




ADDaL 


dataS.dadr 


2.4 

ore 


14(1/2) 






X 


X 


X 


X 


X 


[dadr] — [dadr] + dataS 
Add immediate three bits to memory long word. 2. * 




AND.B 


data8,Dn 


4 


8(2/0) 








X 


X 








[Dn<0-7>1 ^ [Dn<0-7>] A dataS 
AND immediate data byte to data register. Bits 8-31 of the data 
register are not affected. 




AND.B 


dataS.dadr 


4, e 
or 8 


13(2/1)+ 








X 


X 








[dadr] — [dadr] A dataB 
AND immediate data byte to memory byte.'' 




AND.W 


dataie.Dn 


4 


8(2/0) 








X 


X 








[Dn<0-15>] ^ [Dn<0-15>] A data16 
AND immediate data word to data register. Bits 16-31 of the data 
register are not affected. 




AND.W 


dataie.dadr 


4.6 
or 8 


13(2/1) 








X 


X 








[dadr] — [dadr] A data 16 
AND Immediate data word to memory word.2. 3 




AND.L 


data32.Dn 


6 


16(3/0) 








X 


X 








[Dn<0-31>] — [Dn<0-31>] A data32 
AND immediate data long word to data register. 




AND.L 


data32.dadr 


6.8 
or 10 


22(3/2)+ 








X 


X 








[dadr] — [dadr] < data32 
AND immediate data long word to memory.2. 4 



Table 7-6. MC68000 Instruction Set Sunnmary (Continued) 





Mnemonic 


Operand (s) 


Bytes 


Clock 
Cycles 


Status 


Operation Performed 


T 


S 


X 


N 


z 


V 


c 




CMP.B 


dataS.Dn 


4 


8(2/0) 








X 


X 


X 


X 


[Dn<0-7>1 - dataB 
Compare data register byte with immediate data byte and set condi- 
tion codes accordingly. Register data are not changed on any com- 
pares. 




CMP.B 


dataS.dadr 


4,6 
or 8 


8(2/0)+ 








X 


X 


X 


X 


[dadr] - dataS 
Compare memory byte with immediate data byte and set condition 
codes accordingly. 1 




CMP.W 


data16,Dn 


4 


8(2/0) 








X 


X 


X 


X 


[Dn<0-15>l - data16 
Compare data register word with immediate data word and set condi- 
tion codes accordingly. 




CMP.W 


data 16, An 


4 


8(2/0) 








X 


X 


X 


X 


[An<0-15>l - data 16 
Compare address register word with immediate data word and set 
condition codes accordingly. 




CMP.W 


data16,dadr 


4,6 
or 8 


8(2/0)+ 








X 


X 


X 


X 


(dadrl - data 16 
Compare memory word with immediate data word and set condition 
codes accordingly.2. 3 


3 

3 


CMP.L 


data32,Dn 


6 


14(3/0) 








X 


X 


X 


X 


!Dn<0-31>l - da.ta32 
Compare data register with immediate data long word and set condi- 
tion codes accordingly. 


Q. 

S' 
a 

o 


CMP.L 


data32,An 


6 


14(3/0) 








X 


X 


X 


X 


[An<0-31>] - data32 
Compare address register with immediate data long word and set con- 
dition codes accordingly. 


■o 


CMP.L 


data32,dadr 


6,8 
or 10 


12(3/0)+ 








X 


X 


X 


X 


[dadr] - data32 
Compare memory long word with immediate data long word and set 
condition codes accordingly.2. 4 


o 

o 

5' 
c 


DIVS 


data16,Dn 


4 


< 162(2/0) 








X 


X 


X 





[Dn<0-15>] ^ [Dn<0-31>1 ■*■ data16 
[Dn < 16-31 >] — remainder 
Divide signed numbers. Division by zero causes a TRAP. 




DIVU 


data16,Dn 


4 


^148(2/0) 








X 


X 


X 





[Dn<0-15>] "-(Dn<0-31>] h- data16 
[Dn< 16-31 >] ^ remainder 
Divide unsigned numbers. Division by zero causes a TRAP. 




EOR.B 


dataS.Dn 


4 


8(2/0) 








X 


X 








[Dn<0-7>1 — [Dn<0-7>] V dataS 
Exclusive-OR data byte to data register. Bits 8-31 of the data register 
are not affected. 




EOR.B 


dataS.dadr 


4,6 
or 8 


13(2/1)+ 








X 


X 








[dadr] - [dadr] V dataS 
Exclusive-OR data byte to memory byte.^ 




EOR.W 


data16,Dn 


4 


8(2/0) 








X 


X 








[Dn<0-15>] ^ [Dn<0-15>] V datalS 
Exclusive-OR data word to data register. Bits 16-31 of the data register 
are not affected. 




EOR.W 


data16,dadr 


4,6 
or 8 


13(2/1)+ 








X 


X 








[dadr] — [dadrl V data 16 
Exclusive-OR immediate data word to memory word. 2. 3 




EOR.L 


data32,Dn 


6 


16(3/0) 








X 


X 








[Dn<0-31 >] — (Dn>0-31 >] V data32 
Exclusive-OR immediate data long word to data register. 




EOR.L 


data32,dadr 


6,8 
or 10 


22(3/2)+ 








X 


X 








[dadr] -.[dadr] V data32 
Exclusive-OR immediate data long word to memory.2. 4 



Table 7-6. MC68000 Instruction Set Summary (Continued) 





Mnemonic 


Operand (s) 


Bytes 


Clock 
Cycles 


Status 


Operation Performed 


T 


S 


X 


N 


z 


V 


c 




MULS 


data16,Dn 


4 


^74(2/0) 








X 


X 








lDn<0-311>] — [Dn<0-15>] x data16 
Multiply two 16-bit signed numbers, yielding a 32-bit signed product. 




MULU 


data16,Dn 


4 


< 74(2/0) 








X 


X 








[Dn<0-31>] ^[Dn<0-15>] x data16 
Multiply two 16-bit unsigned numbers, yielding a 32-bit unsigned pro- 
duct. 




ORB 


dataS.Dn 


4 


8(2/0) 








X 


X 








[Dn<0-7>] — [Dn<0-7>] V dataS 
OR immediate data byte to data register. Bits 8-31 of the data register 
are not affected. 




ORB 


dataS.dadr 


4, 6 
or 8 


13(2/1)+ 








X 


X 








[dadr] — [dadrl V dataS 
OR immediate data byte to memory byte.^ 




ORW 


data16,Dn 


4 


8(2/0) 








X 


X 








[Dn<0-15>] — [Dn<0-15>] V data16 
OR immediate data word to data register. Bits 16-31 of the data 
register are not affected. 




ORW 


data16.dadr 


4,6 
or 8 


13(2/1)+ 








X 


X 








[dadr] — [dadrl V data 16 
OR immediate data word to memory word.^' 3 




OR.L 


data32.Dn 


6 


16(3/0) 








X 


X 








[Dn<0-31>1 — [Dn<0-31>1 V data32 
OR immediate data long word to data register. 


3 


OR.L 


data32,dadr 


6, 8 
or 10 


22(3/2)+ 








X 


X 








[dadr] — [dadr] V data32 
OR immediate data long word to memory.2. * 


a 
5' 
a 
O 


SUB.B 


dataS.Dn 


4 


8(2/0) 






X 


X 


X 


X 


X 


[Dn<0-7>] — [Dn<0-7>] - dataS 
Subtract immediate data byte from data register. Bits 8-31 of the data 
register are not affected. 


1 


SUB.B 


dataS.dadr 


4,6 
or 8 


13(2/1)+ 






X 


X 


X 


X 


X 


[dadr] — [dadr] - dataS 
Subtract immediate data byte from memory byte.^ 


3' 


SUB.W 


data16,Dn 


4 


8(2/0) 






X 


X 


X 


X 


X 


[Dn<0-15>] — [Dn<0-15>] - data16 
Subtract immediate data word from data register. Bits 16-31 of the 
data register are not affected. 


C 

1 


SUB.W 


data16,An 


4 


8(2/0) 
















[An <0-31>] ^ [An<0-31>] - data16 (sign extended) 
Subtract immediate data word from address register. The sign of the 
data word is extended to a full 32 bits for the operation. 




SUB.W 


data16,dadr 


4,6 
or 8 


13(2/1)+ 






X 


X 


X 


X 


X 


[dadr] — [dadr] - data 16 
Subtract immediate data word from memory word.2. 3 




SUB.L 


data32,Dn 


6 


16(3/0) 






X 


X 


X 


X 


X 


[Dn<0-31 >] ~- [Dn<0-31 >] - data32 
Subtract immediate long word from data register contents. 




SUB.L 


data32,An 


6 


16(3/0) 
















[An<0-31 >] - [An<0-31 >] - data32 
Subtract immediate data long word from address register. 




SUB.L 


data32,dadr 


6.8 
or 10 


22(3/2)+ 






X 


X 


X 


X 


X 


[dadr] — [dadr] - data32 
Subtract immediate data long word from memory word.2. * 




SUBaB 


data3,Dn 


2 


4(1/0) 






X 


X 


X 


X 


X 


[Dn<0-7>] — [Dn<0-7>] - data3 
Subtract immediate three bits from data register byte. Bits 8-31 of the 
data register are not affected. 




SUBaB 


data3,dadr 


2.4 
or 6 


9(1/1)+ 






X 


X 


X 


X 


X 


[dadr] ^ [dadr] - data3 
Subtract immediate three bits from memory byte.l 



Table 7-6. MC68000 Instruction Set Sumnnary (Continued) 





Mnemonic 


Operand(s) 


Bytes 


Clock 
Cycles 


Status 


Operation Performed 


T 


S 


X 


N 


z 


V 





3 
3 
1 
S 
a 

O 

■a 
<s 
3 
a 

O 

o 

3 

5' 


suBaw 

suBaw 

suBaw 
susai 
sueai 
suBai 


data3,Dn 

data3,An 

data3,daclr 
data3,Dn 
dataS.An 
data3,dadr 


2 

2 

2,4 

ore 

2 

2 

2,4 
or 6 


4(1/0) 

4(1/0) 

9(1/1)+ 
8(1/0) 
8(1/0) 
14(1/2)+ 






X 

X 
X 

X 


X 

X 
X 

X 


X 

X 
X 

X 


X 

X 
X 

X 


X 

X 
X 

X 


[Dn<0-15>] — (Dn<0>] - data3 

Subtract immediate three bits from data register word. Bits 16-31 of 

the data register are not affected. 
[An<0-15>] ~- [An<0-15>] - data3 

Subtract immediate three bits from address register word. Bits 16-31 

of the address register are not affected, 
[dadr) ~- [dadr] - data3 

Subtract immediate three bits from memory word. 2. 3 
[Dn<0-31>] — [Dn<0-31>] - data3 

Subtract Immediate three bits from data register contents. 
[An<0-31 >1 — [An<0-31 >] - data3 

Subtract immediate three bits from address register contents, 
[dadr] — [dadr] - data3 

Subtract immediate three bits from memory long word.^. 4 


11 

X 


BRA 
JMP 


label 
jadr 


2 or 4 

2,4 
or 6 


10(2/0) 
4(1/0)+ 
















[PC] — label 

Branch unconditionally (short). 
[PCI - jadr 

Jump unconditionally. 


V) 

c 
o- 
o 

c 

5' 
a 

O 

> 
r- 
1- 
a 

3 
Q. 

30 

m 

C 
39 

Z 


6SR 

JSR 

RTS 
RTR 


label 
jadr 


2 or 
4 

2,4 
or 6 

2 

2 


10, 8(1/0) 
10, 12(2/0) 

14(1/2)+ 

16(4/0) 
20(5/0) 
















[A71 - [A7] - 2 
[[A71] - [PCI 
[PCI — label 

Branch to subroutine (short). 
[A7] - [A7] - 2 
[[A7]l - [PC] 
[PC] - jadr 

Jump to subroutine. 
[PC] - [[A7]] 
[A7] - [A7] + 2 

Return from subroutine 
(SR<0-4>] -[[A7<0-4>]] 
(A71 - [A71 + 2 
[PCI - [(A711 
[A7] - [A7] + 2 

Restore condition codes and return from subroutine. 


S 

3 
3- 
O 

3 

o 

o 

3 
Q. 

r* 

o 

3 


Bcc 
DBcc 


label 
Dn.label 


2 or 
4 

4 


10, 8(1/0) 
10, 12(2/0) 

12(2/0) 
10(2/0), 
14(3/0) 
















[PC] - label 
Branch if condition met. 

If cc then no further action. 

[Dn<0-15>] ^ (Dn<0-15>] - 1 

If [Dn<0-15>] = -1 then no further action. 

[PC] — label 
Test condition, decrement and branch. Loop until the specified condi- 
tion is true or until the loop count is exhausted. 



Table 7-6. MC68000 Instruction Set Summary (Continued) 





Mnemonic 


Operand (s) 


Bytes 


Clock 
Cycles 


Status 


Operation Performed 


T 


S 


X 


N 


z 


V 


c 




MOVE.B 


sDn.dDn 


2 


4(1/0) 








X 


X 


~0~ 


T" 


tdDn<07>] — (sDn<0-7>] 
Move one byte of any data register to any data register. Bits 8-31 of 
the destination register are not affected. 


3 
• 

s 


MOVE.W 


rs,Dn 


2 


4(1/0) 








X 


X 








[Dn<0-15>] — [rs<0-15>] 
IVIove one word of any data or address register to any data register. 
Bits 16-31 of the destination register are not affected. 


SB 
« 

5 


MOVE.W 


rs.An 


2 


4(1/0) 
















[An<015>] — [rs<0-15>] 
[An<16-31>]-[An<15>l 

Move one word of any data or address register to any address register. 

The sign Is extended to all upper bits of the address register. 


3 


MOVE.L 
MOVE.L 


rs,Dn 
rs.An 


2 
2 


4(1/0) 
4(1/0) 








X 


X 








[Dn<0-31>] — [rs<0-31>] 

Move the contents of any data or address register to any data register. 
[An<0-31>1 -[rs<0-31>l 

Move the contents of any data or address register to any address 

register. 




ABCD 


sDn.dDn 


2 


6(1/0) 






X 


u 


X 


u 


X 


[dDn<0-7>] *- [dDn<0-7>] + [sDn<0-7>] + X 
Add decimal source data register byte to destination data register byte 
with carry (Extend bit). Bits 8-31 of the destination data register are 
not affected. 




ADD.B 


sDn.dDn 


2 


4(1/0) 






X 


X 


X 


X 


X 


IdDn<0-7>l — [dDn<0-7>l + [sDn<0-7>] 
Add byte from data registers to data register. Bits 8-31 of the destina- 
tion data register are not affected. 




ADD.W 


rs.Dn 


2 


4(1/0) 






X 


X 


X 


X 


X 


[Dn<0-15>l — [Dn<0-15>] + [rs<0-15>] 
Add word from source register to data register. Bits 16-31 of the 
destination data register are not affected. 




ADD.W 


rs.An 


2 


8(1/0) 
















[An<0-15>] — [An<0-15>] + [rs<0-15>] (sign extended) 
Add word from source register to address register. The sign of the 
source word Is extended to a full 32 bits for the operation. 


1 

do 


ADD! 


rs.Dn 


2 


8(1/0) 






X 


X 


X 


X 


X 


[Dn<0-31>] — [Dn<0-31>] + [rs<0-31>l 
Add long word from source register to data register. 


la 

O 

■o 
o 

1 


ADD.L 
ADDX.B 


rs.An 
sDn.dDn 


2 
2 


8(1/0) 
4(1/0) 






X 


X 


X 


X 


X 


[An<0-31>1 — [An<0-31>] +rs<0-31>l 
Add long word from source register to address register. 

[dDn<0-7>] — tdDn<0-7] + [sDn<0-7>] + X 
Add source data register byte to destination data register byte with 
carry (Extend bit). Bits 8-31 of the destination data register are not 
affected. 




ADDX.W 


sDn, dDn 


2 


4(1/0) 






X 


X 


X 


X 


X 


[dDn<0-15>l »- [dDn<0-15>] + [sDn<0-15>] + X 
Add source data register word to destination data register word with 
carry (Extend bit). Bits 16-31 of the destination data register are not 
affected. 




ADDX.L 


sDn.dDn 


2 


8(1/0) 






X 


X 


X 


X 


X 


[dDn<0-31>] ^[dDn<0-31>l + [sDn<0-31>] + X 
Add source data register long word to destination data register long 
word with carry (Extend bit). 




AND.B 


sDn.dDn 


2 


4(1/0) 








X 


X 








[dDn<0-7>l — [dDn<0-7>] < [sDn<0-7>l 
AND byte from data register to data register. Bits 8-31 of the destina- 
tion data register are not affected. 



Table 7-6. MC68000 Instruction Set Sunnmary (Continued) 













Status 










Mnemonic 


Operand(s) 


Bytes 


Clock 
Cycles 










Operation Performed 


T 


S 


X 


N 


z 


V 


c 




AND.W 


sDn.dDn 


2 


4(1/0) 








X 


X 








[dDn<0-15>] — [dDn<0-15>] < (sDn<0-15>] 
AND word from data register to data register. Bits 16-31 of the 
destination data register are not affected. 




AND.L 


sDn.dDn 


2 


8(1/0) 








X 


X 








[dDn<0-31>l — [dDn<0-31>l < [sDn<0-31>l 
AND long word from data register to data register. 




CMP.B 


sDn.dDn 


2 


4(1/0) 








X 


X 


X 


X 


[dDn<0-7>l - [sDn<0-7>] 
Compare data register bytes and set condition codes accordingly. 
Register data are not changed on any compares. 




CMP.W 


rs.Dn 


2 


4(1/0) 








X 


X 


X 


X 


[Dn<0-15» - [rs<0-15>] 
Compare data register word with register word and set condition 
codes accordingly. 




CMP.W 


rs.An 


2 


6(1/0) 








X 


X 


X 


X 


[An<0-15>] - lrs<0-15>l 
Compare address register word with register word and set condition 
codes accordingly. 




CMP.L 


rs.Dn 


2 


6(1/0) 








X 


X 


X 


X 


[Dn<0-31>] - [rs<0-31>l 
Compare data register with register and set condition codes accor- 


3) 

to 
























dingly. 


IS 


CMP.L 


rs.An 


2 


6(1/0) 








X 


X 


X 


X 


[An<0-31>] - [rs<0-31>] 


2 
























Compare address register with register and set condition codes accor- 


? 
























dingly. 




DIVS 


sDn.dDn 


2 


^158(1/0) 








X 


X 


X 





[dDn<0-15>] ^ [dDn<0-31>] h- [sDn<0-15>] 


5* 
























[dDn<016-31>] ~- remainder 


o 

■o 
























Divide signed numbers. Division by zero causes a TRAP. 


DIVU 


sDn.dDn 


2 


< 140(1/0) 








X 


X 


X 





[dDn<0-15>l ^ [dDn<0-31>] -^ [sDn<0-15>] 


3 
























[dDn< 16-31 >] — remainder 


a 
























Divide unsigned numbers. Division by zero causes a TRAP. 


o 


EOR.B 


sDn.dDn 


2 


4(1/0) 








X 


X 








[dDn<0-7>] ^ [dDn<0-7>] V [sDn<0-7>] 


3 
























Exclusive-OR byte from data register to data register. Bits 8-31 of the 


3' 
c 
























destination data register are not affected. 


1: 


EOR.W 


sDn.dDn 


2 


4(1/0) 








X 


X 








[dDn<0-15>] — [dDn<0-15>] V [sDn<0-15>] 
Exclusive-OR word from data register to data register. Bits 1 6-31 of the 
destination data register are not affected. 




EOR.L 


sDn.dDn 


2 


8(1/0) 








X 


X 








[dDn<0-31>] — [dDn<0-31>] V[sDn<0-31>] 
Excluslve-OR long word from data register to data register. 




EXG 


rs.rd 


2 


6(1/0) 
















(rdl [rs] 

Exchange the contents of two registers. This Is always a long word 
operation. 




MULS 


sDn.dDn 


2 


<70(1/0) 








X 


X 








[dDn<0-31>j — (dDn<0-15>] x [sDn<0-15>] 
Multiply two 16-bit signed numbers, yielding a 32-blt signed product. 




MULU 


sDn.dDn 


2 


< 70(1/0) 








X 


X 








ldDn<0-31>] — [dDn<0-15>] x [sDn<0-15>l 
Multiply two 1 6-bit unsigned numbers, yielding a 32-bit unsigned pro- 
duct. 




ORB 


sDn.dDn 


2 


4(1/0) 








X 


X 








(dDn<0-7>l ^ [dDn<0-7>l V lsDn<0-7>] 
OR byte from data register to data register. Bits 8-31 of the destination 
dat register are not affected. 



Table 7-6. MC68000 Instruction Set Summary (Continued) 





Mnemonic 


Operand(s) 


Bytes 


Clock 
Cycles 


Status 


Operation Performed 


T 


S 


X 


N 


z 


V 


c 




OR.W 
OR.L 


sDn.dDn 
sDn.dDn 


2 
2 


4(1/0) 
8(1/0) 








X 
X 


X 
X 










[dDn<0-15>l — [dDn<0-15>] V [sDn<0-15>] 
OR word from data register to data register. Bits 16-31 of the destina- 
tion data register are not affected. 

(dDn<0-31>] ^ [dDn<0-31>] V [sDn<0-31>] 
OR long word from data register to data register. 




SBCD 


sDn.dDn 


2 


6(1/0) 






X 


u 


X 


u 


X 


[dDn<0-7>] ^ (dDn<0-7>] - [sDn<0-7>l - X 
Subtract decimal source data register byte from destination data 
register byte with carry (Extend bit). Bits 8-31 of the destination data 
register are not affected. 


1 

« 


SUB.B 


sDn.dDn 


2 


4(1/0) 






X 


X 


X 


X 


X 


[dDn<0-7>] — [dDn<0-7>] - [sDn<a7>] 
Subtract data register bytes. Bits 8-31 of the destination data register 
are not affected. 


7 

31 


SUB.W 


rs.Dn 


2 


4(1/0) 






X 


X 


X 


X 


X 


[Dn<0-15>] — [Dn<0-15>] - (rs<0-15>] 
Subtract register words. Bits 16-31 of the destination data register are 
not affected. 


s 

o 

•a 


SUB.W 


rs.An 


2 


8(1/0) 
















(An<0-15>] — [An<0-15>] - (rs<0-15>] (sign extended) 
Subtract source register word from address register. The sign of the 
source word is extended to a full 32 bits for the operation. 


a 
? 

3 
Sf. 
3 

c 


SUB.L 
SUB.L 


rs.Dn 
rs,An 


2 
2 


8(1/0) 
8(1/0) 






X 


X 


X 


X 


X 


[Dn<0-31>] ^ [Dn<0-31>j - [rs<0-31>l 
Subtract source register long word from data register. 

[An<0-31>] — [An<0-31>] - [rs<0-31 >] 

Subtract source register long word from address register. 


o 

a 


SUBX.B 


sDn.dDn 


2 


4(1/0) 






X 


X 


X 


X 


X 


[dDn<0-7>] — [dDn<0-7>l - [sDn<0-7>l - X 
Subtract source data register byte from destination data register byte 
with borrow (Extend bit). Bits 8-31 of the destination data register are 
not affected. 




SUBX.W 


sDn.dDn 


2 


4(1/0) 






X 


X 


X 


X 


X 


[dDn<0-15>l — [dDn<0-15>l - [sDn<0-15>] - X 
Subtract source data register word from destination data register 
word with borrow (Extend bit). Bits 16-31 of the destination data 
registers are not affected. 




SUBX.L 


sDn.dDn 


2 


8(1/0) 






X 


X 


X 


X 


X 


[dDn<0-31>l — [dDn<0-31>) - [sDn<0-31>] - X 
Subtract source data register long word from destination data register 
long word with borrow (Extend bit). 




CLR.B 


Dn 


2 


4(1/0) 











1 








[Dn<0-7>1 ^ 
Clear data register byte to zeroes. Bits 8-31 of the data register are not 
affected. 


31 


CLR.W 


Dn 


2 


4(1/0) 











1 








[Dn<0-15> —0 

Clear data register word to zeroes. Bits 16-31 of the data register are 
not affected. 




CLR.L 
EXT.W 


Dn 
Dn 


2 
2 


6(1/0) 
4(1/0) 









X 


1 

X 










[Dn<0-31>1 —0 

Clear data register to zeroes 
[Dn<8-15>l — [Dn<7>l 

Extend sign bit of data byte to data word size. Bits 16-31 of the data 

register are not affected. 




EXT.L 


Dn 


2 


4(1/0) 








X 


X 








[Dn< 16-31 >] — [Dn<15>l 
Extend sign bit of data word to long data word size. 



Table 7-6. MC68000 Instruction Set Sunnmary (Continued) 





Mnemonic 


Operand (si 


Bytes 


Clock 
Cycles 


Status 


Operation Performed 


























T 


S 


X 


N 


z 


V 


c 






NBCD 


Dn 


2 


6(1/0) 






X 


u 


X 


u 


X 


[Dn<0-7>] -[Dn<0-7>1 -X 
Negate decimal register byte. Bits 8-31 of the data register are not 
affected. 




NEG.B 


Dn 


2 


4(1/0) 






X 


X 


X 


X 


X 


[Dn<0>] ^0 - [Dn<0-7>1 
Negate register byte. Bits 8-31 of the data register are not affected. 




NEG.W 


Dn 


2 


4(1/0) 






X 


X 


X 


X 


X 


[Dn<0-15>l — - [Dn<0-15>l 
Negate register word. Bits 16-31 of the data register are not affected. 




NEG.L 


Dn 


2 


6(1/0) 






X 


X 


X 


X 


X 


[Dn<0-31>1 — 0- [Dn<0-31>1 
Negate register long word. 




NEG.B 


Dn 


2 


4(1/0) 






X 


X 


X 


X 


X 


[Dn<0-7>] - - [Dn<0-71 - X 
Negate register byte with Extend. Bits 8-31 of the data register are not 
affected. 




NEG.W 


Dn 


2 


4(1/0) 






X 


X 


X 


X 


X 


[Dn<0-15>l — - [Dn<0-15>] - X 
Negate register word with Extend. Bits 16-31 of the data register are 
not affected. 


i" 


NEG.L 


Dn 


2 


6(1/0) 






X 


X 


X 


X 


X 


[Dn<0-31>l-0- [Dn<0-31>] -X 


CO 

2. 
























Negate register long word with Extend. 


? 


NOT.B 


Dn 


2 


4(1/0) 








X 


X 








(Dn<0-7>1 -[Dn<0-7>1 


3 
























Ones complement data register byte. Bits 8-31 of the data register are 


<o 
• 


NOT.W 


Dn 


2 


6(1/0) 








X 


X 








not affected. 


[Dn<0-15>] — [Dn<0-15>] 


o 
























Ones complement data register word. Bits 16-31 of the data register 


1 


NOT.L 


Dn 


2 


6(1/0) 








X 


X 








are not affected. 


[Dn<0-3>1 — [Dn<0-31 >] 


a 
























Ones complement data register contents. 


O 


Sec 


Dn 


2 


9(1/1) 
















[Dn<0-7>] — all 1's if cc = TRUE 


*. 
























[Dn <0-1 >] — all O's if cc = FALSE 


c 
• 
























Set status in data register byte. 


a. 


SWAP 


Dn 


2 


4(1/(M 








X 


X 








[Dn<0-15>] lDn<16-31>] 

Exchange the two 16-bit halves of a data register. 




TAS 


Dn 


2 


4(1/0) 








X 


X 








[Dn<7>]^1 
Test status of data register byte and set bit 7 to 1. 




TST.B 


Dn 


2 


4(1/0) 








X 


X 








[Dn<0-7>1 -0 
Test status of data register byte. The data register contents are not 
changed. 




TST.W 


Dn 


2 


4(1/0) 








X 


X 








[Dn<0-15>l - 
Test status of data register word. The data register contents are not 
changed. 




TST.L 


Dn 


2 


4(1/0) 








X 


X 








!Dn<0-31>l-0 
Test status of data register long word. The data register contents are 
not changed. 



Table 7-6. MC68000 Instruction Set Summary (Continued) 





Mnemonic 


Operand(s) 


Bytes 


Clock 
Cycles 


Status 






T 


S 


X 


N 


z 


V 


c 


^—"-' 1 




ASL 


dadr 


2,4 
ore 


9(1/1)+ 






X 


X 


X 


X 


X 


15 




Ict-K-I-. — ■ !ol 




























0-J 

Arithmetic shift left one bit of nnemory word. A zero is shifted into bit 
0. Bit 15 is shifted into both Carry and Extend bits.2. 3 




ASL.B 


count.On 
Dn,dDn 


2 
2 


6 + 2N(1/0) 
6 + 2N(1/0) 






X 
X 


X 
X 


X 
X 


X 
X 


X 
X 


31 8 7 


1 1^.^ H— 1 1 


0- 




























EJ-J 




























Arithmetic shift left of data register byte. The number of shifts is 
specified as a direct count (1-8) or in a data register (1-63). Zeroes are 
shifted into bit 0. Bit 7 is shifted into both Carry and Extend bits. 


M 


ASL.W 


count,Dn 
Dn.dDn 


2 
2 


6 + 2N(1/0) 
6 + 2N(1/0) 






X 
X 


X 
X 


X 
X 


X 
X 


X 
X 


31 16 15 


1 I- 


« 1-4 Inl 


* 1^ IJJ] 


^y*- 




3- 

5 
























EjJ 




























As ASL.B except shifts are for one word. 




ASL.L 


count,Dn 
Dn.dDn 


2 
2 


8 + 2N(1/0) 
8 + 2N(1/0) 






X 
X 


X 
X 


X 
X 


X 
X 


X 
X 


31 


lc^*p^-• »*— 1^* 


























[xJJ 

As ASL.B except shifts are for entire register. 




ASR 


dadr 


2.4 
or 6 


9(1/1)+ 






X 


X 


X 


X 


X 






•J k 1 




r*i , ,_. * r 




D 


*m 


























Arithemtic shift right one bit of memory word. Bit 1 5 is propagated to 
bit 14. Bit is shifted into both Carry and Extend bits. 




ASR.B 


count,Dn 
Dn.dDn 


2 
2 


6 + 2N(1/0) 
6 + 2N(1/0) 






X 
X 


X 
X 


X 
X 


X 
X 


X 
X 


31 8 7 


1 pf -l-p^C| 

— ' writ 


























UJXJ 

Arithmetic shift right of data register byte. The number of shifts is 
specified as a direct count (1-8) or in a data register (1-63). Bit 7 is pro- 
pagated to the right. Bit is shifted into both Carry and Extend bits. 



Table 7-6. MC68000 Instruction Set Summary (Continued) 





Mnemonic 


Operand (s) 


Bytes 


Clock 
Cycles 


Status 




1 


T 


S 


X 


N 


z 


V 


c 






ASR.W 


count.Dn 
Dn.dDn 


2 
2 


6 + 2N(1/0) 
6 + 2N{1/0) 






X 
X 


X 
X 


X 
X 


X 
X 


X 
X 


31 16 15 


1 ri- -hr4£J 

m 


























•-Hxj 

As ASR.B except shifts are for one word. 




ASR.L 


count.Dn 
Dn.dDn 


2 
2 


8 + 2N(1/0) 
8 + 2N(1/0) 






X 
X 


X 
X 


X 
X 


X 
X 


X 
X 


31 


•J k 1 fcin 




1 

As ASR.B except shifts are for entire register. 




LSL 


dadr 


2.4 
ore 


9(1/1)+ 






X 


X 


X 





X 


15 




(cW-l- !o| 




























Logical shift left one bit of memory word. A zero is shifted into bit 0. 
Bit 15 is shifted into both Carry and Extend bits. (Note that LSL is iden- 
tical to ASL except for the Overflow condition.)^. 3 


3; 

? 

5' 
c 


LSL.B 


count.Dn 
Dn.dDn 


2 
2 


6 + 2N(1/0) 
6 + 2N(1/0) 






X 
X 


X 
X 


X 
X 






X 
X 


31 8 7 


I 1- — H— 101 


EH- 




1 
























ig-J 




























Logical shift left of data register byte. The number of shifts is specified 
as a direct count (1-8) or in a data register (1-63). Zeroes are shifted 
into bit 0. Bit 7 is shifted into both Carry and Extend bits. 




LSL.W 


count.Dn 
Dn.dDn 


2 
2 


6 + 2N(1/0) 
6 + 2N(1/0) 






X 
X 


X 
X 


X 
X 






X 
X 


31 16 15 


1 1- 






[cH- 




























[x}-^-l 




























As LSL.B except shifts are for one word. 




LSL.L 


count.Dn 
Dn.dDn 


2 


8 + 2N(1/0) 
8 + 2N(1/0) 






X 
X 


X 
X 


X 
X 






X 
X 


31 




[CJ • 1 • !■• \0\ 


Ix}J 

As LSL.B except shifts are for entire register. 



Table 7-6. MC68000 Instruction Set Summary (Continued) 



Operand (s) 



Bytes 



Clock 
Cycles 



Operation Performed 



LSR 



LSR.B 



LSR.W 



ROL 



count.Dn 
Dn.dDn 



count.Dn 
Dn.dDn 



count.Dn 
Dn.dDn 



count.Dn 
Dn.dDn 



2,4 
or 6 



2.4 
or 6 



9(1/1)+ 



6 + 2N(1/0) 
6 + 2N(1/0) 



6 + 2N(1/0) 
6 + 2N(1/0) 



8 + 2N(1/0) 
8 + 2N(1/0) 



9(1/1)+ 



6 + 2N(1/0) 
6 + 2N(1/0) 



[oi-h: 






Logical shift right one bit of mennory word. A zero is shifted into bit 1 5. 
Bit is shifted into both Carry and Extend bits. 



♦{3 



m h21 



Logical shift right of data register byte. The number of shifts is 
specified as a direct count (1-8) or in a data register (1-63). Zeroes are 
shifted into bit 7. Bit is shifted into both Carry and Extend bits. 



15 



1 - l -pLI 



As LSR.B except shifts are for one word. 
31 



\^}-< 



Eh-© 






As LSR.B except shifts are for entire register. 
15 



[cW-CE 



Rotate left one bit of memory word. Bit 15 is shifted into bit and into 
the Carry. 



Is}- 



^ 



Rotate left of data register byte. The number of shifts is specified as a 
direct count (1-8) or in a data register (1-63). Bit 7 is shifted into bit 
and into the Carry. 



Table 7-6. MC68000 Instruction Set Sumnnary (Continued) 



Operand(s) 



Bytes 



Clock 
Cycles 



T S 



Operation Performed 



ROL.W 



ROR.W 



countDn 
Dn,dDn 



count.Dn 
Dn.dDn 



count.Dn 
Dn,dOn 



count.On 
Dn.dDn 



count.Dn 
Dn.dDn 



2.4 
or 6 



2,4 
or 6 



6 + 2N(1/0) 
6 + 2N(1/0) 



8 + 2N(1/0) 
8 + 2N(1/0) 



9(1/1)+ 



6 + 2N(1/0) 
6 + 2N(1/0) 



6 + 2N(1/0) 
6 + 2N(1/0) 



8 + 2N(1/0) 
8 + 2N(1/0) 



9(1/1)+ 



S*i 



As ROL. B except shifts are for one word. 
31 



©-rC 



As ROL.B except shifts are for entire register. 
15 



*m 



Rotate right one bit of memory word. Bit is shifted into bit 15 and 
into the Carry. 



&r® 



Rotate right of data register byte. The number of shifts is specified as a 
direct count (1-8) or in a data register (1-63). Bit is shifted into bit 7 
and into the Carry. 



31 



16 15 



*-(cJ 



As ROR.B except shifts are for one word. 
31 



± 



hrm 



As ROR.B except shifts are for entire register. 

15 



h-S m 



Rotate left one bit of memory word and Extend one bit. Bit 1 5 is shifted 
into both Extend and Carry bits. The Extend bit is shifted into bit 0. 



Table 7-6. MC68000 Instruction Set Sumnnary (Continued) 



Operand Is I 



Bytes 



Clock 
Cycles 



Operation Performed 



ROXL.L 



count.Dn 
Dn.dDn 



count.Dn 
Dn.dDn 



count.Dn 
Dn.dDn 



count.Dn 
Dn.dDn 



count.Dn 
Dn.dDn 



2.4 
or 6 



+ 2N(1/0) 
+ 2N(1/0) 



6 + 2N(1/0) 
6 + 2N(1/0) 



8 + 2N(1/0) 
8 + 2N(1/0) 



9(1/1)+ 



6 + 2N(1/0) 
6 + 2N(1/0) 



6 + 2N{1/0) 
6 + 2N(1/0) 




^rU" 



Rotate left of data register byte with Extend. The number of shifts is 
specified as a direct count (1-8) or in a data register (1-63). Bit 15 Is 
shifted Into both Extend and Carry bits. The Extend bit Is shifted Into 
bit 0. 



31 



16 15 



-|xi m 



As ROXL.B except shifts are for one word. 
31 



h-0 Ip 



As ROXL.B except shifts are for entire register. 
15 



h m 



-m 



Rotate right one bit of memory word and Extend. Bit is shifted Into 
both Extend and Carry bits. The Extend bit Is shifted Into bit 1 5. 



m d 



Rotate right of data register byte with Extend. The number of shifts is 
specified as a direct count (1-8) or in a data register (1-63). Bit is 
shifted into both Extend and Carry bits. The Extend bit Is shifted Into 
bit 7. 




As ROXR.B except shifts are for entire register. 



Table 7-6. MC68000 lnstructi>n Set Summary (Continued) 





Mnemonic 


Operand (s) 


Bytes 


Clock 
Cycles 


Status 1 


Operation Performed 


T 


S 


X 


N 


Z 


V 


c 


n 
S 

u 

3 
0) 

:*. 
o 

3 


BTST 
BTST 

BSET 

BCLR 

BCHG 


bitl.Dn 
Dn.dDn 

bitb.dadr 
Dn.dadr 

bitl.Dn 
Dn.dDn 
bitb.dadr 

Dn.dadr 

bitl.Dn 
Dn.dDn 
bltb.dadr 

Dn.dadr 

bitl,Dn 
Dn.dDn 
bitb.dadr 

Dn.dadr 


4 
2 

4.6 
ore 
2.4 
or 6 

4 

2 
4.6 
or 8 
2.4 
or 6 

4 

2 
4,6 
or 8 
2.4 
or 6 

4 

2 
4.6 
or 8 
2.4 
or 6 


10(2/0) 
6(1/0) 

8(2/0)+ 
4(1/0)+ 

12(2/0) 

8(1/0) 

13(2/1)+ 

9(1/1)+ 

14(2/0) 

8(1/0) 

13(2/1)+ 

9(1/1)+ 

12(2/0) 

8(1/0) 

13(2/1) 

9(1/1) 










X 
X 

X 
X 

X 
X 
X 

X 

X 
X 
X 

X 

X 
X 
X 

X 






[Zl — [Dn<bitl>) 

[Zl — [dDn<[Dn]>l 
Test a bit of a data register and reflect status in Zero bit. The bit to be 
tested may be specified directly or in a data register (bit 0-31 in either 
case). 


[Z] — ldadr<bitb>J 


[Zl — ldadr<[DnJ>J 
Test a bit of a memory byte and reflect status in Zero bit. The bit to be 
tested may be specified directly or in a data register (bit 0-7 in either 
case).1 


[Z] — [Dn<bitl>). lDn<bltl>J — 1 
(Zl — [dDn<lDn]>l. [dDn<[Dnl> — 1 
[Zl — [dadr<bitb>l. [dadr<bitb>] — 1 


[Zl - [dadr<[Dnl>l, ldadr<[Dnl>l - 1 
Test a bit as (BTST) and then set the specified bit. 


[Z] ~ [Dn<bitl>l, [Dn<bitl>l - 
[Z] ~ [dDn<[Dnl>l. [dDn<[Dnl>l ^0 
[Zl — [dadr<bitb>l. [dadr <bit b>] — 


[Zl — [dadr<[Dn]>l, [dadr<[Dnl>l — 

Test a bit (as BTST) and then clear the specified bit. 
[Zl — [Dn<bitl>l, [Dn<bitl>l — [Dn<bitl>l 
[Zl - [dOn -- [Dnl>l. [dDn<[Dnl>l, [dDn<[dDnl>l 
[Zl — [dadr<bitb>l, [dadr<bitb>l — [dadr<bitb>l 


[Zl - [dadr<[Dnl>l, [dadr<[Dnl>l — ldadr<[Dnl>l 
Test a bit (as BTST) and then complement the specified bit. 


1 


MOVE 
MOVE 
LINK 

PEA 


An.USP 
USP.An 
An,d16 

jadr 


2 
2 

4 

2.4 
ore 


4(1/0) 
4(1/0) 
18(2/2) 

10(1/2)+ 
















[USPl - [Anl 
Move contents of address register to User Stack Pointer. This is a pri- 
vileged Instruction. 

[Anl - [USPl 
Move contents of User Stack Pointer to address register. This Is a pri- 
vileged instruction. 

[A71 — [A71 - 2 

[[A71] - [Anl 

[Anl - [A71 

[A 71 — [A 71 + d16 
Save the contents of the specified address register on the Stack, load 
the current Stack Pointer to the specified address register, and set the 
Stack Pointer to point beyond the temporary stack storage area. 

[A71 - [A71 - 2 

[[A7]l - jadr 
Compute long word address and push address onto the Stack.3 



Table 7-6. MC68000 Instruction Set Sunnnnary (Continued) 





Mnemonic 


Operand(s) 


Bytes 


Clock 
Cycles 


Status 


Operation Performed 


T 


s 


X 


N 


z 


V 


c 




UWLK 


An 


2 


12(3/0) 
















[A7] - [An] 

[An] - [[A7]] 

[A7] - [A7] + 2 
Store the contents of the specified address register to the Stack 
Pointer (A 7) and load the specified address register from the stack. 


3 
9 

c 
•o 

Ql 

3 

a. 

3 

•0 


CHK 

TRAP 

TRAPV 
RTE 


data16,Dn 

Dn.dDn 

sadr.Dn 

vector 


4 

2 

2.4 
or 6 

2 

2 
2 


49(6/3), 

12(2/0) 

45(5/3), 

8(1/0) 

45(5/3), 

8(1/0) 

37(4/3) 

37(5/3), 
4(1/0) 

20(5/0) 






X 


X 
X 
X 

X 


u 
u 
u 

X 


u 
u 
u 

X 


u 
u 
u 

X 


If [Dn<0-15>] < Dor [Dn<0-15>] > datalB 
then [PC] ^ CHK interrupt vector 

If [dDn<0-15>] < Oor [dDn<0-15>] > [Dn<0-15>] 
then [PC] — CHK interrupt vector 

If [Dn<0-15>] <0or [Dn<0-15>] > [sadr] 
then [PC] — CHK interrupt vector 

Check register against bounds and initiate Check interrupt processing 
if register word is out of bounds. The upper bound is a twos comple- 
ment integer specified as immediate data, in a data register, or in a 
memory word. 2, 3 

[A7] - [A7] - 2 

[[A7]l - [PC] 

[A7] - [A7] - 2 

[[A7]] - [SR] 

[PCI — vector 
Initiate exception processing through specified vector. 

If Overflow = 1 then TRAP 

Initiate exception processing through Overflow vector if the Overflow 
bit is on. 

[SR] - [[A7]], [A71 - (A7] + 2 

[PC] - [[A7]]. [A7] - [A7] + 2 
Return from exception. 


1 


MOVE 
MOVE 

MOVE 
MOVE 

MOVE 

MOVE 

MOVE 


Dn.CCr 
sadr.CCR 

data8,CCR 
Dn.SR 

sadr.SR 

data16,SR 

SR,Dn 


2 

2,4 
or 6 

4 

2 

2,4 
or 6 

4 
2 


12(2/0) 
12(2/0)+ 

16(3/0) 
12(2/0) 

12(2/0)+ 

16(3/0) 

6(1/0) 


X 
X 
X 


X 
X 
X 


X 
X 

X 
X 

X 

X 


X 
X 

X 
X 

X 

X 


X 
X 

X 
X 

X 

X 


X 
X 

X 
X 

X 

X 


X 
X 

X 
X 

X 

X 


[SR<0-4>] — [Dn<0-4] 

Move status data from data register to condition codes. 
[SR<0-4>] [sadr<0-4>] 

Move status data from memory location to condition codes. The 

source address is a word address.2, 3 
[SR<0-4>] — data8<0-4> 

Move immediate status data to condition codes. 

[SR] ^ [Dn<0-15>] 

Moves status word from data register to Status register. This is a pri- 
vileged instruction. 

[SR] — [sadr] 
Move status word from memory location to Status register. This is a 
privileged instruction. The source address is a word address. 2, 3 

[SR] —data 16 

Move immediate status word to Status register. This is a privileged 

instruction. 
[Dn<0-15>] - [SR] 

Move contents of Status register to data register. Bits 16-31 of the 

data register are not affected. 



Table 7-6. MC68000 Instruction Set Summary (Continued) 





Mnemonic 


Operand (s) 


Bytes 


Clock 
Cycles 


Status 


Operation Performed 


T 


s 


X 


N 


z 


V 


c 


1 

c 

V 

3 

3 
C 

1 


MOVE 

AND.B 
AND.W 

EOR.B 
EOR.W 

ORB 
OR.W 


SR,dadr 

dataaSR 
data16.SR 

dataS.SR 
dataie.SR 

dataS.SR 
dataie.SR 


2,4 
or 6 

4 

4 

4 
4 

4 
4 


9(1/1)+ 

20(3/0) 
20(3/0) 

20(3/0) 
20(3/0) 

20(3/0) 
20(3/0) 


X 
X 
X 


X 
X 
X 


X 
X 

X 
X 

X 
X 


X 
X 

X 
X 

X 
X 


X 
X 

X 
X 

X 
X 


X 
X 

X 
X 

X 
X 


X 
X 

X 
X 

X 
X 


[dadr] — [SR] 

Move contents of Status register to memory location. The destination 

address is a word address. 2, 3 
[SR<0-7>] — [SR<0-7>1 A dataS 

AND immediate data byte to low-order Status register byte. 
[SR] ^ [SR] A data 16 

AND immediate data with Status register. This is a privileged 

instruction. 
[SR<0-7>] - [SR<0-7>1 VdataS 

Exclusive-OR immediate data byte to low-order Status register byte. 
[SR] — [SR] V data 16 

Exclusive-OR immediate data with Status register. This is a privileged 

instruction. 

[SR<0-7>] - [SR<0-7>1 < dataS 
OR immediate data byte to low-order Status register byte. 

[SR] ^[SR] Vdata16 
OR immediate data with Status register. This is a privileged instruc- 
tion. 


s 

8 
o 

X 

3 

a 

o 

O 

o 

3 


NOP 

RESET 

STOP 


data 16 


2 
2 

4 


4(1/0) 

132(1/0) 

8(2/0) 






X 


X 


X 


X 


X 


No operation. 

Reset. This is a privileged instruction. 
[SR] - data 16 
Stop processor. This is a privileged instruction. 



Table 7-7. MC68000 Instruction Object Codes 



Instruction 



Byte 1 Byte 2 Byte 3 Byte 4 Byte S Byte 6 Byte 7 Byte 8 Byte 9 Byte 10 



Bytes 


Clock Cycles 


2 


19(3/1) 


2 


6(1/0) 


4, 6, or 8 


13(2/1)+ 


4 


8(2/0) 


2, 4, or 6 


9(1/1)+ 


2, 4, or 6 


4(1/0 + 


2 


4(1/0) 


6 


16(3/0) 


6, 8, or 10 


22(3/2)+ 


6 


16(3/0) 


2, 4, or 6 


14(1/2) + 


2 


8(1/0) 


2 


8(1/0) 


2, 4, or 6 


6(1/0)+ 


2, 4, or 6 


6(1/0)+ 


4 


8(2/0) 


4, 6. or 8 


13(2/1) 


4 


8(2/0) 


2, 4, or 6 


9(11)+ 


2 


8(1/0) 


2 


4(1/0) 


2, 4, or 6 


8(1/0) + 


2, 4, or 6 


4(1/0) + 


2, 4, or 6 


9(1/0) + 


2 


4(1/0) 


2 


8(1/0) 


2, 4, or 6 


14(1/2)+ 


2 


8(1/0) 


2 


4(1/0) 


2, 4, or 6 


9(1/1)+ 


2 


4(1/0) 


2 


19(3/1) 


2 


4(1/0) 


2 


32(5/2) 


2 


8(1/0) 


2 


19(3/1) 


2 


4(1/0) 


4, 6, or 8 


13(2/1) + 


4 


8(2/0) 


4 


20(3/0) 


2, 4, or 6 


9(1/1) + 


2, 4, or 6 


4(1/0)+ 


2 


4(1/0) 


6, 8, or 10 


22(3/2)+ 


6 


16(3/0) 


2, 4, or 8 


14(1/2)+ 


2, 4, or 6 


6(1/0) + 


2 


8(1/0) 


4, 6, or 8 


13(2/1)+ 


4 


8(2/0) 


4 


20(3/0) 


2, 4, or 6 


9(1/1) 


2, 4, or 6 


4(1 /O) 



ABCD 
ADD.B 



AODQ.B 
ADDQ.L 

ADDQ.W 

ADDX.B 
ADDX.L 
ADDX.W 
AND.B 



AND.L 



-(SAn),-(dAn) 

sDn.dDn 

data8,dadr 

data8,Dn 

Dn.dadr 

sadr.Dn 

sDn.dDn 

data32,An 

data32,dadr 

data32,Dn 

Dn.dadr 

rs.An 

rs.Dn 

sadr.An 

sadr.Dn 

data 16, An 

data16,dadr 

dataie.Dn 

Dn.dadr 

rs.An 

rs.Dn 

sadr.An 

sadr.Dn 

data3.dadr 

dataS.Dn 

dataS.An 

data3.dadr 

data3.Dn 

data3.An 

data3.dadr 

data3,Dn 

-(sAn).-(dAn) 

sDn.dDn 

-(sAn).-(dAn) 

SDn.dDn 

-(sAn).-(dAn) 

sDn.dDn 

dataB.dadr 

dataS.Dn 

dataB.SR 

Dn.dadr 

sadr.Dn 

sDn.dDn 

data32.dadr 

data32.Dn 

Dn.dadr 

sadr.Dn 

sDn.dDn 

data16.dadr 

data16.Dn 

data16.SR 

Dn.dadr 

sadr.Dn 



dddl 

6 

6 

sssi 

dddl 

dddO 



ddddl Isss 
dddd 1 Osss 
6 OOff ffff 
6 Oddd 

sssi OOff ffff 
dddO OOee eeee 
dddO Osss 

F C 
lOff ffff 

8 Oddd 
lOff ffff 

C tsss 

8 tsss 
dddl 1 lee eeee 
dddO 1 0ee eeee 
dddO F C 
6 01 ff ffff 
6 4 Oddd 

ssssi 01 ff ffff 
dddO C tsss 
dddO 4 tsss 
dddO 1 lee eeee 
dddO lee eeee 
bbbO OOff ffff 
bbbO Oddd 
bbbO 8 Iddd 
bbbO 1 0ff ffff 
bbbO 8 Oddd 
bbbO 4 1 ddd 
bbbO 01 ff ffff 
bbbO 4 Oddd 





8 



dddl 

dddl 

dddl 

dddl 

ddd1 

dddl 

2 

2 

2 



1sss 
Osss 
Isss 
8 Osss 
4 Isss 
4 Osss 
OOff ffff 
Oddd 
3 C 
sssi OOff ffff 
dddO OOeeaaee 
dddO Osss 
2 1 0ff ffff 
2 8 Oddd 

sssi 1 0ff ffff 
dddO lOeeeeee 
dddO 8 Osss 
2 01 ff ffff 
2 4 Oddd 

2 7 C 

sssi 01 ff ffff 
dddO lee eeee 



00 yy 

00 yy 

[EXT] 
[EXTl 

yyyy 
yyyy 
yyyy 
[EXTl 



[EXTl 
(EXTl 

yyyy 
yyyy 
yyyy 

[EXTl 



[EXTl 
[EXTl 
[EXTl 



[EXTl 
[EXTl 



[EXTl 

[EXTl 
[EXTl 

zzzz 
zzzz 
zzzz 

(EXTl 



[EXTl 
(EXTl 



[EXTl 
lEXTl 



[EXTl 
(EXTl 
[EXTl 



[EXTl 



[EXTl 



[EXTl 



[EXTl 



[EXTl 



[EXTl 



00 yy 

00 yy 

00 yy 

[EXTl 
[EXTl 

yyyy 
yyyy 

[EXTl 
[EXTl 

yyyy 
yyyy 
yyyy 

[EXTl 
[EXTl 



[EXTl 



(EXTl 
(EXTl 

ZZZZ 
zzzz 

[EXTl 
[EXTl 

[EXTl 



[EXTl 
[EXTl 



[EXTl 



(EXTl 



[EXTl 



[EXTl 



Table 7-7, MC68000 Instruction Object Codes (Continued) 





Instruction 




sDn.dDn 


ASL 


dadr 


ASLB 


count.Dn 




Dn.dDn 


ASL.L 


count.Dn 




Dn.dDn 


ASL.W 


count.Dn 




Dn.dDn 


ASR 


dadr 


ASR.B 


count.Dn 




Dn.dDn 


ASR.L 


count.Dn 




Dn.dDn 


ASR.W 


count.Dn 




Dn.dDn 


BCC 


label 




label 


BCHG 


bitb.dadr 




bItl.Dn 




Dn.dadr 




Dn.dDn 


BCLR 


bitb.dadr 




bItl.Dn 




Dn.dadr 




Dn.dDn 


BOS 


label 




label 


BEQ 


label 




label 


BGE 


label 




label 


BGT 


label 




label 


BHI 


label 




label 


BLE 


label 




label 


BLS 


label 




label 


BLT 


label 


BMI 


label 




label 


BNE 


label 




label 


BPL 


label 




label 


BRA 


label 




label 


BSET 


bitb.dadr 




bitl.Dn 




Dn.dadr 




Dn.dDn 



Byte 1 Byte 2 Byte 3 Byte 4 Byte 5 Byte 6 Byte 7 Byte 8 Byte 9 Byte 10 



Bytes 


Clock Cycles 


2 


4(1/0) 


2, 4. or 6 


9(1/1)+ 


2 


6 + 2N(1/0) 


2 


6 + 2N(1/0) 


2 


8 + 2N(1/0) 


2 


8 + 2N(1/0) 


2 


6 + 2N(1/0) 


2 


6 + 2N(1/0) 


2. 4. or 6 


9(1/1) + 


2 


6 + 2N(1/0) 


2 


6 + 2N(1/0) 


2 


8 + 2N(1/0) 


2 


8 + 2N(1/0) 


2 


6 + 2N(1/0) 


2 


6 + 2N(1/0) 


4 


10.12(2/0) 


2 


10.18(1/0) 


4. 6. or 8 


13(2/1) + 


4 


12(2/0) 


2, 4. or 6 


9(1/1)+ 


2 


8(1/0) 


4. 6. or 8 


13(2/1) + 


4 


14(2/0) 


2. 4. or 6 


9(1/1)+ 


2 


8(1/0) 


4 


10.12(2/0) 


2 


10.18(1/0) 


4 


10.12(2/0) 


2 


10,8(1/0) 


4 


10.12(2/0) 


2 


10.8(1/0) 


4 


10,12(2/0) 


2 


10.8(1/0) 


4 


10.12(2/0) 


2 


10.8(1/0) 


4 


10.12(2/0) 


2 


10.8(1/0)1 


4 


10.12(2/0) 


2 


10,8(1/0) 


4 


10.12(2/0) 


2 


10.8(1/0) 


4 


10.12(2/0) 


2 


10.8(1/0) 


4 


10.12(2/0) 


2 


10.8(1/0) 


4 


10.12(2/0) 


2 


10,8(1/0) 


4 


10(2/0) 


2 


10(1/0) 


4. 6. or 8 


13(2/1)+ 


4 


12(2/0) 


2, 4, or 6 


9(1/1)+ 


2 


8(1/0) 



dddO 

1 

ccci 

rrri 

ccci 

rrri 

ccci 

rrri 



cccO 

rrrO 

cccO 

rrrO 

cccO 

rrrO 

4 

4 

8 

8 

rrri 

rrri 

8 

8 

rrri 

rrri 

5 

5 

7 

7 

C 

C 

E 

E 

2 

2 

F 

F 

3 

3 

D 

D 



6 

6 

6 

6 

6 

6 

6 

6 B 

6 B 

6 6 

6 6 

6 

6 

6 

6 











A 

A 





8 

8 

rrri 

rrri 



4 Osss 
llff fftf 

Oddd 

2 Oddd 

8 Oddd 

A Oddd 

4 Oddd 

6 Oddd 
llff ff ft 

Oddd 

2 Oddd 

8 Oddd 

A Oddd 

4 Oddd 

6 Oddd 



X X 

Olff ffff 

4 Oildd 
Olff ffff 

4 Oddd 
lOff fftt 

8 Oddd 
1 0ff ffff 

8 Oddd 



X X 



X X 





X 



X 





X 











X X 

1 1 ff ffff 

C Oddd 
llff ffff 
C Oddd 



:exti 



:exti 



<(XXX 

''<0 Obbb 

''<0 000b bbbb 

:ext) 

'jO Obbb 

00 000b bbbb 
lEXTl 

XXXX 
XXXX 

xxxx 

xxxx 

xxxx 

xxxx 

xxxx 

xxxx 

xxxx 

xxxx 

nxxx 

xxxx 

00 Obbb 

00 000b bbbb 
ieXTj 



lEXT! 



[EXT! 

[EXTl 
rcvTi 


tEXTl 



[EXTl 
[EXTl 



[EXTl 



[EXTl 
[EXTl 



[EXTl 



Table 7-7. MC68000 Instruction Object Codes (Continued) 





Instruction 


BSR 


label 




label 


BTST 


bitb.dadr 




bitl,Dn 




Dn.dadr 




Dn.dDn 


BVC 


label 




label 


BVS 


label 


CHK 


data16,Dn 




Dn,dDn 




sadr.Dn 


CLR.B 


dadr 




Dn 


CLR.L 


dadr 




Dn 


CLR.W 


dadr 




Dn 


CMP. B 


dataS.dadr 




dataS.Dn 




sadr.Dn 




sDn.dDn 


CMP. L 


data32,An 




data32,dadr 




data32,Dn 




rs.An 




rs,Dn 




sadr.An 




sadr.Dn 


CMP.W 


data 16, An 




data16,dadr 




data16,Dn 




rs.An 




rs.Dn 




sadr.An 




sadr.Dn 


CMPM. B 


(sAn)+,(dAn) + 


CMPM, L 


(sAn)+,(dAn)+ 


CMPM. W 


(sAn)+,(dAn)+ 


DBCC 


Dn.label 


DBCS 


Dn.label 


DBEQ 


Dnjabel 


DBF 


DnJabel 


DBGE 


Dn.label 


DBGT 


Dn.label 


DBHI 


Dn.label 


DBLE 


Dn.label 


DBLS 


Dn.label 


DBLT 


Dn.label 


DBMI 


Dn.label 


DBNE 


Dn.label 


DBPL 


Dn.label 



Byte 1 Byte 2 Byte 3 Byte 4 Byte 5 Byte 6 Byte 7 Byte 8 Byte 9 Byte 10 



Bytes 


Clock Cycles 


4 


10,12(2/0) 


2 


10.8(1/0) 


4. 6. or 8 


8(2/0) + 


4 


10(2/0) 


2. 4. or 6 


4(1/0) 


2 


6(1/0) 


4 


10,12(2/0) 


2 


10.8(1/0) 


4 


10.12(2/0) 


2 


10.8(1/0) 


4 


49(6/3). 12(2/0) 


2 


45(5/3).8(1/0) 


2, 4, or 6 


45(5/3)+.81/0) 


2, 4, or 6 


9(1/1) + 


2 


4(1/0) 


2. 4, or 6 


14(1/2) + 


2 


6(1/0) 


2. 4, or 6 


9(1/1) 


2 


4(1/0) 


4, 6. or 8 


8(2/0) 


4 


8(2/0) 


2, 4. or 6 


4(1/0) + 


2 


4(1/0) 


6 


14(3/0) 


6, 8, or 10 


12(3/0)+ 


6 


14(3/0) 


2 


6(1/0) 


2 


6(1/0) 


2. 4. or 6 


6(1/0) + 


2. 4. or 6 


6(1/0) + 


4 


8(2/0) 


4, 6. or 8 


8(2/0) + 


4 


8(2/0) 


2 


6(1/0) • 


2 


4(1/0) 


2. 4, or 6 


6(1/0) + 


2. 4, or 6 


4(1/0) + 


2 


12(3/0) 


2 


20(5/0) 


2 


1 2(3/0) 


4 


12(2/0). 10(2/0). 14(3/0) 


4 


12(2/0). 10(2/0). 14(3/0) 


4 


12(2/0). 10(2/0). 14(3/0) 


4 


12(2/0).10(2/0).1 4(3/0) 


4 


12(2/0). 10(2/0), 14(3/0) 


4 


12(2/0).10(2/0).1 4(3/0) 


4 


12(2/0),10(2/0).14(3/0) 


4 


12(2/0).10(2/0).1 4(3/0) 


4 


12(2/0).1 0(2/0). 14(3/0) 


4 


12(2/0). 10(2/0). 14(3/0) 


4 


12(2/0).10(2/0).1 4(3/0) 


4 


12(2/0). 10(2/0). 14(3/0) 


4 


12(2/0). 10(2/0). 14(3/0) 



6 1 

6 1 

8 

8 

rrri 

rrri 

6 8 

6 8 

6 9 





X X 

OOf f fff f 
Oddd 

OOff ffff 
Oddd 




9 

dddl 

dddl 

dddl 

2 

2 

2 

2 

2 

2 

C 

C 

B dddO 
B dddO 
B dddl 
C 
C 
B dddl 
B dddO 
B dddl 
B dddO 
B dddO 
C 
C 
B dddO 
B dddO 
B dddO 
B dddO 
B dddl 
B dddl 
B dddl 
5 4 

5 

7 

1 

C 

E 

2 

F 

3 

D 

B 





X X 

B C 
8 Orrr 
1 0ee eeee 
OOff ffff 

Oddd 
1 0ff ffff 

8 Oddd 
01 ff ffff 

4 Oddd 
OOff ffff 

Oddd 
OOeeeeee 
Osss 
F C 
1 0ff ffff 
8 Oddd 
C tsss 
8 tsss 
1 lee eeee 
1 0ee eeee 

F C 
01 ff ffff 
4 Oddd 
C tsss 
tsss 
eeee 
eeee 
Isss 
Isss 
Isss 
Irrr 
Irrr 
Irrr 
Irrr 
Irrr 
Irrr 
Irrr 
Irrr 
Irrr 
Irrr 
Irrr 
Irrr 
Irrr 



xxxx 

00 Obbb 

00 OOObbbbb 

[EXTI 

xxxx 



(EXTI 
[EXT! 

(EXTI 

lEXTl 

00 yy 

00 yy 

[EXT! 

vvyy 

WW 
WW 



[EXTI 
[EXT] 
WW 
WW 
WW 



[EXTI 
[EXTI 



[EXT] 



4 


tsss 


1 lee eeee 


lee eeee 





Isss 


8 


Isss 


4 


Isss 



[EXT] 
[EXT] 



xxxx 
xxxx 
xxxx 
xxxx 
xxxx 
xxxx 
xxxx 
xxxx 
xxxx 
xxxx 
xxxx 
xxxx 
xxxx 



[EXTI 
[EXTI 

(EXTI 

[EXT] 

[EXT! 

[EXTI 

zzzz 
zzzz 
zzzz 



[EXTI 
[EXTI 



lEXTl 



(EXTI 
[EXTI 



(EXTI 



(EXTI 



(EXTI 



[EXTI 



Table 7-7. MC68000 Instruction Object Codes (Continued) 





Instruction 


DBRA 


Dn,label 


DBT 


Dn.label 


DVC 


Dn.label 


DVS 


Dn.label 


DIVS 


dataie.Dn 




sadr.Dn 




sDn.dDn 


DIVU 


data16,0n 




sadr.Dn 




sDn.dOn 


EOR.B 


data8.dadr 




dataS.Dn 




dataS.SR 




Dn.dadr 




sDn.dDn 


EOR. L 


data32,dadr 




data32,Dn 




Dn.dadr 




sOn.dDn 


EOR.W 


data16.dadr 




dataie.Dn 




data16.Sr 




Dn.dadr 




sDn.dDn 


EXG 


An,An 




An.Dn 




Dn.An 




Dn.Dn 


EXT.L 


Dn 


EXT.W 


Dn 


JMP 


jadr 


JSR 


jadr 


LEA 


jadr.An 


LINK 


An.d16 


LSL 


dadr 


LSL.B 


count.Dn 




Dn.dDn 


LSL.L 


count.Dn 




Dn.dDn 


LSL.W 


count.Dn 




Dn.dDn 


LSR 


dadr 


LSR.B 


count.Dn 




Dn.dDn 


LSR.L 


count.Dn 




Dn.dDn 


LSR.W 


count.Dn 




Dn.dDn 


MOVE 


An.USP 




dataS.CCR 




data16.SR 




Dn.CCR 




Dn.SR 



Byte 1 Byte 2 Byte 3 Byte 4 Byte 5 Byte 6 Byte 7 Byte 8 Byte 9 Byte 10 



Bytes 


Clock Cycles 


4 


12(2/0).10(2/0).14(3/0) 


4 


12(2/0),10(2/0).14(3/0) 


4 


12(2/0).10(2/0),14(3/0) 


4 


< 162(2/0) 


2. 4. or 6 


< 158(1/0)+ 


2 


< 158(1/0) 


4 


< 148(2/0) 


2, 4, or 6 


< 140(1/0)+ 


2 


< 140(1/0) 


4, 6, or 8 


13(2/1)+ 


4 


8(2/0) 


4 


20(3/0) 


2. 4. or 6 


9(1/1)+ 


2 


4(1/0) 


6. a. or 10 


22(3/2)+ 


6 


16(3/0) 


2. 4. or 6 


14(1/2)+ 


2 


8(1/0) 


4, 6. or 8 


13(2/1) + 


4 


8(2/0) 


4 


20(3/0) 


2. 4. or 6 


9(1/1)+ 


2 


4(1/0) 


2 


6(1/0) 


2 


6(1/0) 


2 


6(1/0) 


2 


4(1/0) 


2 


4(1/0) 


2. 4. or 6 


4(1/0)+ 


2. 4. or 6 


14(1/2)+ 


2. 4. or 6 


2(0/0) + 


4 


18(2/2) 


2, 4, or 6 


9(1/1) + 


2 


6 + 2N(1/0) 


2 


6 + 2N(1/0) 


2 


8 + 2N(1/0) 


2 


8 + 2N(1/0) 


2 


6 + 2N(1/0) 


2 


6 + 2N(1/0) 


2. 4. or 6 


9(1/1)+ 


2 


6 + 2N(1/0) 


2 


6 + 2N(1/0) 


2 


8 + 2N(1/0) 


2 


8 + 2N(1/0) 


2 


6 + 2N(1/0) 


2 


6 + 2N(1/0) 


2 


4(1/0) 


4 


16(3/0) 


4 


16(3/0) 


2 


12(2/0) 


2 


12(2/0) 



(same 



8 



5 

5 

5 9 

8 ddd1 

8 dddl 

8 dddl 

8 dddO 

8 dddO 

8 dddO 

A 

A 

A 

B sss1 

B sssi 

A 

A 

B sssi 

B sssi 

A 

A 

A 

B sssi 

B sssi 
sssi 
sssi 
(same 
sssi 
8 
8 
E 
E 

4 dddl 

4 E 
3 

ccci 
rrri 
ccci 
rrri 
ccci 
rrri 
2 

cccO 
rrrO 
cccO 
rrrO 
cccO 
rrrO 
E 
4 
6 
4 



4 6 



as DBF) 
C 1-rr 
C Vrr 
C 1-rr 
F C 

11eee0ee 
C Osss 
F C 

lleeeeea 
C Osss 

OOff ffft 
Oddd 

3 C 
OOff ftff 

Oddd 
lOffffff 

8 Oddd 
lOffffff 

8 Oddd 
Olffffff 

4 Oddd 

7 C 
Olffffff 

4 Oddd 
4 Iddd 

8 Iddd 
as An.Dn) 

4 Oddd 
C Oddd 
8 Oddd 

II111J1I 
lOijJiii 
llllllll 

5 Orrr 
llffffff 

Iddd 
2 Iddd 
8 Iddd 
A Iddd 
4 Iddd 

6 Iddd 
llffffff 

lildd 
2 Iddd 
8 Iddd 
A Iddd 
4 Iddd 
6 Iddd 
6 Osss 
F C 
F C 
C Osss 
C Osss 



xxxx 
xxxx 
xxxx 
wyy 
iEXTl 

WW 

lEXTj 

00 yy 

00 yy 

00 yy 

IEXTl 

vyyy 
vyyy 
[EXT] 

yyyy 
wyy 
vyyy 
IEXTl 



[EXT] 

(EXTl 
[EXT] 

lEXT) 

zzzz 
»zz 

IEXTl 

IEXTl 
IEXTl 



[EXTl 



IEXTl 



IEXTl 



IEXTl 



IEXTl 
IEXTl 
■EXTl 

(EXTl 



iEXTl 



IEXTl 
IEXTl 
IEXTl 
xxxx 
[EXTl 



IEXTl 



')0 yy 

yyyy 



Table 7-7. MC68000 Instruction Object Codes (Continued) 



Instruction 


Byte 1 Byte 2 Byte 3 Byte 4 Byte 5 Byte 6 


Byte 7 Byte 8 Byte 9 Byte 10 


Bytes 


Clock Cycles 




sadr.CCR 


4 4 lleeeeee 


[EXTl 


[EXTl 




2, 4. or 6 


12(2/0)+ 




sadr.SR 


4 6 11ee«aae 


lEXTl 


[EXTl 




2. 4, or 6 


12(2/0)+ 




SR,dadr 


4 llffffff 


[EXTl 


(EXTl 




2, 4. or 6 


9(1/1)+ 




SR.Dn 


4 C Oddd 








2 


6(1/0) 




USR,An 


4 E 6 Isss 








2 


4(1/0) 


M0VE.8 


dataS.Dn 


1 dddO 3 C 00 yy 






4 


8(2/0) 




dataS.dadr 


1 ggggggiic oo yy 


(EXTl 


(EXTl 


4, 6. or 8 


9(1/1)+ 




Dn.dadr 


1 ggggggOOOsss 


lEXTl 


(EXTl 




2, 4. or 6 


5(0/1)+ 




sDadDn 


1 dddO Osss 








2 


4(1/0) 




sadr.dadr 


1 ggggggeeeeee 


[EXTsl 


(EXTsl 


(EXTdl [EXTdl 


2. 4, 6, 8 or 10 


5(1/1)+ 




sadr.Dn 


1 dddOOOeeeeee 


[EXTl 


[EXTl 




2. 4, or 6 


4(1/0)+ 


MOVE. L 


An.dadr 


2 ggggggOdsss 


(EXTl 


(EXTl 




2. 4. or 6 


10(0/2) + 




data32,An 


2 dddO 7 C 


yyyy 


Z2ZZ 




6 


12(3/0) 




data32,dadr 


2 ggggggiic 


yyyy 


zzzz 


[EXTl (EXTl 


6, 8, or 1 


18(2/2)+ 




data32,Dn 


2 dddO 3 C 


yyyy 


zzzz 




6 


12(3/0) 




Dn.dadr 


2 ggggggOOOsss 


[EXTl 


(EXTl 




2. 4. or 6 


10(0/2)+ 




rs,An 


2 dddO 4 tsss 








2 


4(1/0) 




rs.Dn 


2 dddO tsss 








2 


4(1/0) 




sadr.An 


2 dddOOIee'eeee 


(EXTl 


(EXTl 




2. 4, or 6 


8(2/0)+ 




sadr.dadr 


2 gggg ggeeieeee 


[EXTsl 


(EXTsl 


(EXTdl (EXTdl 


2. 4. 6. 8. or. 10 


14(1/2)+ 




sadr.Dn 


2 dddOOOee,eeee 


[EXTl 


[EXTl 




2. 4. or 6 


4(1/0)+ 


MOVE. W 


An,dadr 


3 ggggggOdsss 


(EXT! 


(EXTl 




2. 4. or 6 


5(0/1)+ 




data 16, An 


3 dddO 7 .C 


yyyy 






4 


8(2/0) 




data16,dadr 


3 ggggggiic 


vvyy 


(EXTl 


(EXTl 


4, 6. or 8 


9(1/1)+ 




data16,Dn 


3 dddO 3 C 


yyyy 






4 


8(2/0) 




Dn,dadr 


3 ggggggOOOsss 


[EXTl 


(EXTl 




2, 4, or 6 


5(0/1)+ 




rs.An 


3 dddO 4 tsss 








2 


4(1/0) 




rs.Dn 


3 dddO tsss 








2 


4(1/0) 




sadr.An 


3 dddOOIeeseee 


(EXTl 


(EXTl 




2. 4. or 6 


4(1/0) + 




sadr.dadr 


3 ggggggeeeeee 


[EXTsl 


(EXTsl 


(EXTdl [EXTdl 


2.4.6.8,or10 


5(0/1) + 




sadr.Dn 


3 dddOOOeeeaee 


(EXTl 


(EXTl 




2. 4. or 6 


4(1/0) + 


MOVEM. L 


(An)+.reg-list 


4 E Osss 


mmmm 






4 


8 + 8n(2 + 2n/0) 




jadr.reg-list 


4 C llijjjjj 


mmmm 


(EXTl 


[EXTl 


4. 6, or 8 


8 + 8n(2 + 2n/0)+ 




reg-list.-(An) 


4 8 E Oddd 


kkkk 






4 


4+ 10n(1/n) 




reg-list.madr 


4 8 llhhhhhh 


mmmm 


(EXTl 


(EXTl 


4. 6, or 8 


4+10n(1/n) + 


MOVEM. W 


(An)+,reg-list 


4 A Osss 


mmmm 






4 


8 + 4n(2 + n/0) 




jadr.reg-list 


4 C lOjjjjJi 


mmmm 


[EXTl 


[EXT] 


4. 6, or 8 


8 + 4n(2 + n/0)+ 




reg-list,-(An) 


4 8 A Oddd 


kkkk 






4 


4 + 5n(1/n) 




reg-list.madr 


4 8 lOhhhhhh 


mmmm 


(EXTl 


(EXTl 


4. 6. or 8 


4 + 5n(1/n) + 


MOVER. L 


d16(An).Dn 


dddl 4 Isss 


xxxx 






4 


24(6/0) 




Dn.d16(An) 


sssi C Iddd 


xxxx 






4 


28(2/4) 


MOVER. W 


d16(An).Dn 


ddd1 Isss 


xxxx 






4 


16(4/0) 




On.dielAn) 


sssi 8 Iddd 


xxxx 






4 


18(2/2) 


MOVED 


dataS.Dn 


7 dddO y y 








2 


4(1/0) 


MULS 


dataie.Dn 


C dddl F C 


yyyy 






4 


< 74(2/0) 




sadr.Dn 


C dddl lleeeeee 


(EXTl 


(EXTl 




2. 4. or 6 


< 70(1/0) + 




sDn.dDn 


C dddl C Osss 








2 


< 70(1/0) 


MULU 


data16.Dn 


C dddO F C 


yyyy 






4 


< 74(2/0) 




sadr.Dn 


C dddO lleeeeee 


(EXTl 


(EXTl 




2. 4. or 6 


< 70(1/0)+ 




sDn.dDn 


C dddO C Osss 








2 


< 70(1/0) 


NBCD 


dadr 


4 8 OOffffff 


[EXTl 


[EXTl 




2, 4, or 6 


9(1/1) + 




Dn 


4 8 Oddd 








2 


6(1/0) 


NEG. B 


dadr 


4 4 OOff ffff 


(EXTl 


(EXTl 




2. 4. or e 


9(1/1) + 



Table 7-7. MC68000 Instruction Object Codes (Continued) 





Instruction 




Dn 


NEG.L 


dadr 




Dn 


NEG.W 


dadr 




Dn 


NEGX.B 


dadr 




Dn 


NEGX.L 


dadr 




Dn 


NEGX.W 


dadr 




Dn 


NOP 




NOT.B 


dadr 




Dn 


NOT.L 


dadr 




Dn 


NOT.W 


dadr 




Dn 


OR. B 


dataS.dadr 




dataS.Dn 




dataS.SR 




Dn,dadr 




sadr.Dn 




sDn,dDn 


OR. L 


data32.dadr 




data32.Dn 




Dn.dadr 




sadr.Dn 




sDn,dDn 


OR.W 


dataie.dadr 




data16,Dn 




dataie.SR 




Dn.dadr 




sadr.Dn 




sDn.dDn 


PEA 


jadr 


RESET 




ROL 


dadr 


ROLB 


count.Dn 




Dn,dDn 


ROLL 


count.Dn 




Dn.dDn 


ROL.W 


count.Dn 




Dn.dDn 


ROR 


dadr 


ROR.B 


count.Dn 




Dn.dDn 


ROR.L 


count.Dn 




Dn.dDn 


ROR.W 


count.Dn 




Dn.dDn 


ROXL 


dadr 


ROXLB 


count.Dn 



Byte 1 Byte 2 Byte 3 Byte 4 Byte 5 Byte 6 Byte 7 Byte 8 Byte 9 Byte 1( 



Bytes 


Clock Cycles 


2 


4(1/0) 


2. 4, or 6 


14(1/2) + 


2 


6(1/0) 


2. 4. or 6 


9(1/1) 


2 


4(1/0) 


2. 4, or 6 


9(1/1) + 


2 


4(1/0) 


2. 4. or 6 


14(1/2) + 


2 


6(1/0) 


2. 4. or 6 


9(1/1)+ 


2 


4(1/0) 


2 


4(1/0) 


2, 4. or 6 


9(1/1) + 


2 


4(1/0) 


2. 4, or 6 


14(1/2) + 


2 


6(1/0) 


2. 4. or 6 


9(1/1)+ 


2 


6(1/0) 


4. 6. or 8 


13(2/1)+ 


4 


8(2/0) 


4 


20(3/0) 


2. 4. or 6 


9(1/1) + 


2. 4. or 6 


4(1/0)+ 


2 


4(1/0) 


6. 8, or 10 


22(3/2)+ 


6 


16(3/0) 


2, 4. or 6 


14(1/2)+ 


2. 4, or 6 


6(1/0) + 


2 


811/0) 


4, 6. or 8 


13(2/1) + 


4 


8(2/0) 


4 


20(3/0) 


2. 4, or 6 


9(1/1) + 


2. 4, or 6 


4(1/0) + 


2 


4(1/0) 


2. 4. or 6 


10(1/2) + 


2 


132(1/0) 


2. 4. or 6 


9(1/1) + 


2 


6 + 2N(1/0) 


2 


6 + 2N(1/0) 


2 


8 + 2N(1/0) 


2 


8 + 2N(1/0) 


2 


6 + 2N(1/0) 


2 


6 + 2N(1/0) 


2.4or6 


9(1/1) + 


2 


6 + 2N(1/0) 


2 


6 + 2N(1/0) 


2 


8 + 2N(1/0) 


2 


8 + 2N(1/0) 


2 


6 + 2N(1/0) 


2 


6 + 2N(1/0) 


2. 4. or 6 


9(1/1) + 


2 


6 + 2N(1/0) 



8 dddO 

8 dddO 





8 sssi 

8 dddO 

8 dddO 







a ssi 

8 dddO 

8 dddO 

8 

E 

7 

ccci 
rrri 
ccci 
rrri 
ccci 
rrri 
6 

cccO 
rrrO 
cccO 
rrrO 
cccO 
rrrO 
5 
ccci 



0.idd 
lOff ffft 

8 Oddd 
Olff ffff 

4 Odda 
OOff ffff 

Oddd 
1 0ff ffff 

8 Oddd 
Olff ffff 

4 Oddd 

7 1 
OOff ffff 

OJdd 
1 0ff ffff 

8 Oddd 
Olff ffff 

4 Oddd 
OOff ffff 
Oddd 

3 C 
OOff ffff 
OOeeotien 

03S5 

1 0ff ffff 
8 Oddd 

lOfffftl 

lOeeefoo 
8 Osss 

Olff ffff 

4 Oldd 
7 C 

lOff fitf 
Oleeeaee 

4 OsSS 

01 II iiii 

7 

1 1ff ffff 



1 Iddd 

3 Iddd 

9 Iddd 

B 1 lidn 

5 Iddd 

7 Udd 



1 1 ff ffff 
1 1 JcJd 



3 1 ddd 

9 Iddd 

B Iddd 

5 Iddd 

7 1 ddd 
1 1 ff ffff 

1 Oddd 



lEXTl 
lEXTl 

:exti 

lEXTl 

:exti 

EXT] 
i.EXTl 
lEXTj 



yy 



'JO 

■jO yy 

■JO yy 

iEXTl 

EXTl 

vyyy 
vyyy 

.EXT) 
iEXTl 

yyyy 
vyyy 
yyyy 

IEXTl 
'EXTl 

:exti 



IEXTl 



IEXTl 



[EXTl 
[EXTl 
[EXTl 
[EXTl 
(EXTl 

[EXTl 
[EXTl 
IEXTl 
[EXTl 



[EXTl 
(EXTl 

zzzz 
zzzz 

[EXTl 
[EXT] 

[EXTl 



[EXTl 
[EXTl 



[EXTl 
[EXTl 



[EXTl 



[EXTl 



[EXTl 

[EXTl 

[EXTl 
[EXTl 



[EXTl 



Table 7-7. MC68000 Instruction Object Codes (Continued) 



Instruction 



Byte 1 Byte 2 Byte 3 Byte 4 Byte 5 Byte 6 Byte 7 Byte 8 Byte 9 Byte 1 



Bytes 


Clock Cycles 


2 


6 + 2N(1/0) 


2 


8 + 2N(l/0) 


2 


8 + 2N(1/0) 


2 


6 + 2N(1/0) 


2 


6 + 2N(1/0) 


2, A, or 6 


9(1/1) + 


2 


6 + 2N(1/0) 


2 


6 + 2N(1/0) 


2 


8 + 2N(1/0) 


2 


8 + 2N(1/0) 


2 


6 + 2N(1/0) 


2 


6 + 2N(1/0) 


2 


20(5/0) 


2 


20(5/0) 


2 


16(4/0) 


2 


19(3/1) 


2 


6(1/0) 


2. 4, or 6 


9(1/1) + 


2 


6,4(1/0) 


2, 4, or 6 


9(1/1) + 


2 


6,4(1/0) 


2, 4, or 6 


9(1/1) + 


2 


6,4,(1/0) 


2, 4, or 6 


9(1/1) + 


2 


6,4(1/0) 


2, 4, or 6 


9(1/1) + 


2 


6,4(1/0) 


2, 4, or 6 


9(1/1) 


2 


6,4(1/0) 


2, 4, or 6 


9(1/1) + 


2 


6,4,(1/0) 


2, 4, or 6 


9(1/1) + 


2 


6,4(1/0) 


2, 4, or 6 


9(1/1) + 


2 


6,4(1/0) 


2, 4, or 6 


9(1/1) + 


2 


6,4(1/0) 


2. 4, or 6 


9(1/1) + 


2 


6,4(1/0) 


2, 4, or 6 


9(1/1) + 


2 


6,4(1/0) 


2. 4, or 6 


9(1/1) + 


2 


6,4(1/0) 


2, 4, or 6 


9(1/1)+ 


2 


6,4(1/0) 


4 


8(2/0) 


4, 6, or 8 


13(2/1)+ 


4 


8(2/0) 


2, 4, or 6 


9(1/1)+ 


2, 4, or 6 


4(1/0) + 


2 


4(1/0) 


6 


16(3/0) 


6, 8, or 10 


22(3/2) + 



ROXL.L 

ROXL.W 

ROXR 
ROXR.B 

ROXR.L 

ROXR.W 

RTE 
RTR 
RTS 
SBCD 

sec 

SOS 

SEQ 

SF 

SGE 

SGT 

SHI 

SLE 

SLS 

SLT 

SMI 

SNE 

SPL 

ST 

STOP 
SUB. B 



SUB. L 



DadDn 

countDn 

Dn,dDn 

count,Dn 

Dn,dDn 

dadr 

countDn 

Dn,dDn 

count,Dn 

Dn,dDn 

countDn 

Dn,dDn 



-(sAn),-(dAn) 

sDadDn 

dadr 

Dn 

dadr 

Dn 

dadr 

Dn 

dadr 

Dn 

dadr 

Dn 

dadr 

Dn 

dadr 

Dn 

dadr 

Dn 

dadr 

Dn 

dadr 

Dn 

dadr 

Dn 

dadr 

Dn 

dadr 

Dn 

dadr 

Dn 

data 16 

data8,dadr 

data8,Dn 

Dn,dadr 

sadr,Dn 

sDn.dDn 

data32,An 

data32,dadr 



Oddd 
Oddd 



rrri 

ccci 

rrri 

ccci 

rrri 

4 1 1 f f f f f f 



B Oddd 



Oddd 
Oddd 



cccO 1 



rrrO 

cccO 

rrrO 

cccO 

rrrO 

E 

E 

E 

8 dddl 
8 dddl 
5 4 

4 

5 

5 

7 

7 

1 

1 

C 

C 

E 

E 

2 

2 

F 

F 

3 

3 

D 

D 

B 

B 

6 

6 

A 

A 





E 

4 

4 



Oddd 

Oddd 

Oddd 

Oddd 

Oddd 

Oddd 

3 

7 

5 

Isss 

Osss 



1 1 ff ffff 
C Oddd 

1 1 tf ffff 
C Oddd 

I 1 ff ffff 
C Oddd 

Ifff ffff 
C Oddd 

I I ff ffff 
C Oddd 

1 1 ff ffff 

C Oddd 
llff ffff 

C Oddd 
1 1 f f ffff 

C Oddd 
1 1 ff ffff 

C Oddd 
llff ffff 

C Oddd 
llff ffff 

C Oddd 
1 1 ff ffff 

C Oddd 
llff ffff 

C Oddd 
llff ffff 

C Oddd 

7 2 
OOff ffff 

Oddd 
sssi OOff ffff 
9 dddOOOeeeeee 
9 dddO Osss 
9 dddl F C 
4 1 0ff ffff 



[EXT] 



[EXTl 



lEXTl 
[EXT] 
lEXTl 
lEXTl 
[EXTl 
[EXTl 
[EXTl 
[EXTl 
[EXT] 
[EXTl 
[EXTl 
[EXTl 
[EXTl 
[EXTl 
yVYY 

00 vv 

00 yy 

[EXTl 
[EXTl 

yyyy 
vyyy 



[EXTl 
[EXT! 
[EXTl 
[EXTl 
[EXTl 
[EXTl 
[EXTl 
[EXTl 
[EXTl 
[EXTl 
[EXTl 
[EXTl 
[EXTl 
[EXTl 

[EXTl 

[EXTl 
[EXTl 

zzzz 
zzzz 



[EXTl 



[EXTl 



[EXTl 



Table 7-7. MC68000 Instruction Object Codes (Continued) 





Instruction 




clata32,Dn 




Dn.dadr 




rs,An 




rs.Dn 




sadr.An 




sadr.Dn 


SUB.W 


data 16, An 




data16,dadr 




data16,Dn 




Dn.dadr 




rs.An 




rs.Dn 




sadr.An 




sadr.Dn 


SUBQ. B 


dataS.dadr 




data3,Dn 


SUBQ.L 


dataS.An 




dataS.dadr 




dataS.Dn 


SUBQ.W 


dataS.An 




dataS.dadr 




dataS.Dn 


SUBX.B 


-(sAn). -(dAn) 




sDn, dDn 


SUBX.L 


-(sAn).-(dAn) 




sDn.dDn 


SUBX.W 


-(sAn).-(dAn) 




sDn.dDn 


SVC 


dadr 




Dn 


SVS 


dadr 




Dn 


SWAP 


Dn 


TAS 


dadr 




Dn 


TRAP 


vector 


TRAPV 




TST.B 


dadr 




Dn 


TST.L 


dadr 




Dn 


TST.W 


dadr 




Dn 


UNLK 


An 



Byte 1 Byte 2 Byte 3 Byte 4 Byte 5 Byte 6 Byte 7 Byte 8 Byte 9 Byte 1 



Bytes 


Clock Cycles 


6 


16(3/0) 


2. 4, or 6 


14(1/2) + 


2 


8(1/0) 


2 


8(1/0) 


2. 4. or 6 


6(1/0)+ 


2. 4. or 6 


6(1/0) + 


4 


8(2/0) 


4, 6, or 8 


13(2/1) + 


4 


8(2/0) 


2. 4. or 6 


9(1/1) + 


2 


8(1/0) 


2 


4(1/0) 


2. 4. or 6 


8(1/0) + 


2. 4. or 6 


4(1/0)+ 


2. 4. or 6 


9(1/1) + 


2 


4(1/0) 


2 


8(1/0) 


2. 4. or 6 


14(1/2) + 


2 


8(1/0) 


2 


4(1/0) 


2. 4, or 6 


9(1/1) + 


2 


4(1/0) 


2 


19(3/1) 


2 


4(1/0) 


2 


32(5/2) 


2 


8(1/0) 


2 


19(3/1) 


2 


4(1/0) 


2. 4, or 6 


9(1/1)+ 


2 


6.4(1/0) 


2. 4. or 6 


9(1/1) + 


2 


6.4(1/0) 


2 


4(1/0) 


2. 4, or 6 


11(1/1)+ 


2 


4(1/0) 


2 


36(4/3) 


2 


37(5/3).4(1/0) 


2. 4. or 6 


4(1/0) + 


2 


4(1/0) 


2, 4, or 6 


4(1/0)+ 


2 


4(1/0) 


2, 4. or 6 


4(1/0)+ 


2 


4(1/0) 


2 


12(3/0) 



4 

sssi 
dddl 
dddO 
dddl 
dddO 
dddO 
4 
4 

sssi 
dddO 
dddO 
9 dddO 
9 dddO 
bbbi 
bbbi 
bbbi 
bbbi 
bbbi 
bbb1 
bbbi 
bbbi 
dddl 
dddl 
dddl 
dddl 
ddJl 
dddl 
8 
8 
9 
9 
8 
A 
A 
E 
E 
A 
A 
A 
A 
A 
A 
E 



8 Oddd 
lOffffff 

C tsss 

8 tsss 
1 1 eeeeee 
lOeeeeee 

F C 
Olffffff 

4 Oddd 
Olffffff 

C tSbb 

4 tssis 
1 1eee(>i>B 
01 eeeeee 
OOff ffff 
Oddd 
8 Iddd 
lOffffff 
8 Oddd 
4 Iridd 
Olffffff 



4 OJdd 
Isss 
Osss 
8 Isss 
8 Ossb 
4 Isss 
4 Osss 

1 1ff ffff 
C Oddd 

1 1 ff ffff 
C OJdd 
4 Orrr 

1 1 ff ff f ff 
C Orrr 
4 Ovvv 

7 6 
OOff ffff 

Otf 
lOffffff 

8 Orrr 
Olffffff 

4 O-rr 

5 1.-rr 



yyyy 

[EXT] 



[EXTI 
[EXT] 

yyyy 
yyyy 
yyyy 

lEXTI 



:exti 

lEXTl 
lEXTl 



I EXT I 



.EXTI 



zzzz 

(EXT) 



[EXTI 
[EXTI 



(EXTI 
(EXTI 



[EXT] 
[EXT] 
[EXT] 



[EXT] 
[EXT] 



[EXT] 



:ext] 

(EXTI 
[EXT] 

[EXTI 
[EXT] 
lEXT] 



[EXTI 
[EXT] 

[EXT] 

[EXTI 
lEXT] 
[EXT] 



Table 7-8. MC68000 Object Codes in Numerical Order 



Byte 1 Byte 2 Byte 3 Byte 4 Byte S Byte 6 Byte 7 Byte 8 Byte 9 Byte 10 





Instruction 


ORB 


dataS.Dn 


ORB 


dataS.dadr 


OR.B 


dataS.SR 


OR.W 


data16,Dn 


OR.W 


data16,dadr 


OR.W 


data16,SR 


OR.L 


data32,Dn 


OR.L 


data32,dadr 


BTST 


Dn.dDn 


MOVEP.W 


d16(An),Dn 


BTST 


Dn.dadr 


BCHG 


Dn.dDn 


MOVEP.L 


d16(An),Dn 


BCHG 


Dn.dadr 


BCLR 


Dn.dDn 


MOVEP.W 


Dn.d16(An) 


BCLR 


Dn.dadr 


BSET 


Dn.dDn 


MOVEP.L 


Dn,d16(An) 


BSET 


Dn.dadr 


AND.B 


dataS.Dn 


AND.B 


dataS.dadr 


AND.B 


dataS.SR 


AND.W 


dataie.Dn 


AND.W 


data16.dadr 


AND.W 


dataie.SR 


AND.L 


data32,Dn 


AND.L 


data32.dadr 


SUB.B 


dataS.Dn 


SUB.B 


dataS.dadr 


SUB.W 


dataie.Dn 


SUB.W 


data16,dadr 


SUB.L 


data32.Dn 


SUB.L 


data32.dadr 


ADD.B 


dataS.Dn 


ADD.B 


dataS.dadr 


ADD.W 


dataie.Dn 


ADD.W 


dataie.dadr 


ADD.L 


data32.Dn 


ADD.L 


data32.dadr 


BTST 


bitl.Dn 


BTST 


bitb.dadr 


BCHG 


bitl.Dn 


BCHG 


bitb.dadr 


BCLR 


bitl.Dn 


BCLR 


bitb.dadr 


BSET 


bitl.Dn 


BSET 


bitb.dadr 


EOR.B 


dataS.Dn 


EOR.B 


dataS.dadr 


EOR.B 


dataS.SR 


EOR.W 


dataie.Dn 


EOR.W 


dataie.dadr 


EOR.W 


dataie.SR 


EOR.L 


data32.Dn 


EOR.L 


data32.dadr 


CMP.B 


dataS.Dn 


CMP.B 


dataS.dadr 


CMP.W 


dataie.Dn 


CMP.W 


dataie.dadr 


CMP.L 


data32.Dn 


CMP.L 


data32.dadr 


MOVE.B 


sDn.dDn 


MOVE.B 


sadr.Dn 


MOVE.B 


dataS.Dn 


MOVE.B 


Dn.dadr 


MOVE.B 


sadr.dadr 


MOVE.B 


dataS.dadr 


MOVE.L 


rs.Dn 


MOVE.L 


sadr.Dn 


MOVE.L 


data32.Dn 


MOVE.L 


rs.An 


MOVE.L 


sadr.An 



00 
00 
00 
00 
00 
00 
00 
00 
Orrrl 



Oddd 
OOff ffff 

3 C 

4 Oddd 
01 ff ffff 

7 C 

8 Oddd 
lOff ffff 

Oddd 



Odddl isss 
nrl OOff ffff 
rrrl A Oddd 
Odddl A Isss 
rrrl 01 ff ffff 
rrrl S Oddd 
Osssi S Iddd 
Orrrl 1 0ff ffff 
rrrl C Oddd 
Osssi C Iddd 
Orrrl 1 1ff ffff 



02 
02 
02 
02 
02 
02 
02 
02 
04 
04 
04 
04 
04 
04 
06 
06 
06 
06 
06 
06 
08 
08 
08 
08 
08 
08 
08 
08 
OA 
OA 
OA 
OA 
OA 
OA 
OA 
OA 
OC 
OC 
OC 
OC 
OC 
OC 

1 

1 

1 

1 

1 

1 



Oddd 
OOff ffff 

3 C 

4 Oddd 
01 ff ffff 

7 C 

8 Oddd 
1 0ff ffff 

Oddd 
OOff ffff 

4 Oddd 
01 ff ffff 

8 Oddd 
1 0ff ffff 

Oddd 
OOff ffff 

4 Oddd 
01 ff ffff 

5 Oddd 
1 0ff ffff 

Oddd 
OOff ffff 

4 Oddd 
01 ff ffff 

5 Oddd 
1 0ff ffff 

C Oddd 
1 1ff ffff 

Oddd 
OOff ffff 

3 C 

4 Oddd 
Iff ffff 

7 C 

8 Oddd 
1 0ff ffff 

Oddd 
OOff ffff 

4 Oddd 
01 ff ffff 

8 Oddd 
1 0ff ffff 
dddO Osss 
dddO OOeeeeee 
dddO 3 C 

asoeggOOOsss 

gags ggee eeee 
gggg gg 1 1 C 
2 dddOOOOOtsss 
2 dddO OOee eeee 
2 dddO 3 C 
2 dddOOIOOtsss 
2 dddOO lee eeee 



00 
00 
00 



yyyy 
yyyy 
yyyy 
yyyy 
yyyy 



[EXT. 



xxxx 

[ext; 



xxxx 

[ext; 



xxxx 
[EXT 



00 
00 
00 



yyyy 
yyyy 
yyyy 
yyyy 
yyyy 



00 
00 



yy 



yyyy 
yyyy 
yyyy 
yyyy 

00 

00 yy 

yyyy 
yyyy 
yyyy 
yyyy 
00 OOObbbbb 
Gbbb 
OOObbbbb 
Obbb 
OOObbbbb 
Obbb 
000b bbhb 
Obbb 

yy 



00 
00 
00 
00 
00 
00 
00 
00 
00 



yyyy 
yyyy 
yyyy 
yyyy 
yyyy 



00 
00 



yyyy 
yyyy 
yyyy 
yyyy 

lEXTl 

00 yy 

(EXTl 

[EXTsl 

00 yy 

[EXT] 

yyyy 

[EXTl 



[EXT] 

lEXT] 

zzzz 
zzzz 

'EXTl 

'.EXTl 

fEXTl 

'EXTl 
lEXTl 

lEXTl 

zzzz 
zzzz 

:exti 

.EXTl 
zzzz 
zzzz 

.EXTl 

.EXTl 
zzzz 
zzzz 

'EXTl 

.EXTl 

EXTl 

EXTl 

:exti 

EXTl 

zzzz 
zzzz 

EXTl 

:exti 

zzzz 
zzzz 

;exti 

[EXTl 
lEXTjl 

lEXTj 

(EXTl 
zzzz 

[EXTl 



[EXTl 
lEXTl 
[EXTl 



[EXTl 



[EXTl 

[EXTl 

[EXT] 
[EXTl 
lEXTl 
[EXT] 
[EXTl 
[EXTl 
[EXTl 
[EXTl 
[EXTl 
[EXTl 
[EXTl 
[EXTl 

[EXTl 

[EXTl 
[EXTl 
[EXTl 
[EXTl 



[EXTdl 
[EXTl 



[EXTl 



[EXTl 



[EXTl 



[EXTl 



lEXTl 



[EXTh 
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Table 7-8. MC68000 Object Codes in Numerical Order (Continued) 



Byte 1 Byte 2 Byte 3 Byte 4 Byte 5 Byte 6 Byte 7 Byte 8 Byte 9 Byte 1 



Instruction 


MOVE.L 


data32,An 


MOVE.L 


rs.dadr 


MOVE.L 


sadr.dadr 


MOVEL 


data32,dadr 


MOVE.W 


rs.Dn 


MOVE.W 


sadr.Dn 


MOVE.W 


data16,0n 


MOVE.W 


rs.An 


MOVE.W 


sadr.An 


MOVE.W 


data 16, An 


MOVE.W 


rs.dadr 


MOVE.W 


sadr.dadr 


MOVE.W 


dataie.dadr 


NEGX.B 


Dn 


NEGX.B 


dadr 


NEGX.W 


Dn 


NEGX.W 


dadr 


NEGX.L 


Dn 


NEGX.L 


dadr 


MOVE 


SR.Dn 


MOVE 


SR.dadr 


CHK 


Dn.dDn 


CHK 


sadr.Dn 


CHK 


dataie.Dn 


LEA 


jadr.An 


CLR.B 


Dn 


CLR.B 


dadr 


CLR.W 


Dn 


CLR.W 


dadr 


CLR.L 


Dn 


CLR.L 


dadr 


NEG.B 


Dn 


NEG.B 


- dadr 


NEG.W 


Dn 


NEG.W 


dadr 


NEG.L 


Dn 


NEG.L 


dadr 


MOVE 


Dn,CCR 


MOVE 


sadr.CCR 


MOVE 


dataS.CCR 


NOT.B 


Dn 


NOT.B 


dadr 


NOT.W 


Dn 


NOT.W 


dadr 


NOT.L 


Dn 


NOT.L 


dadr 


MOVE 


Dn.SR 


MOVE 


sadr.SR 


MOVE 


dataie.SR 


NBCD 


Dn 


NBCD 


dadr 


SWAP 


Dn 


PEA 


jadr 


EXT.W 


Dn 


MOVEM.W 


reg-list.madr 


MOVEM. W 


reg-list.-(An) 


EXT.L 


Dn 


MOVEM. L 


reg-list.madr 


MOVE. L 


reg-list.-(An) 


TST.B 


Dn 


TST.B 


dadr 


TST.W 


Dn 


TST.W 


dadr 


TST.L 


Dn 


TST.L 


dadr 


TAS 


Dn 


TAS 


dadr 


MOVEM. W 


jadr.reg-list 


MOVEM.W 


(An)+,reg-rist 


MOVEM. L 


(An)+.reg-list 


MOVEM. L 


jadr.reg-list 


MOVEM. L 


(An)+.reg-list 


TRAP 


vector 



2ddGtO 


7 C 


yyyv 


29999 ggootss 


[EXTI 


29999 ggeeeeee 


lEXTsI 


29999 ggiic 


yyyy 


3d«wp 


tsss 




SdddOOOeeeeee 


[EXT] 


SdddO 


3 C 


yyyy 


3ddcf0 


4 tsss 




3ddd001eeeeee 


[EXTl 


3ddd0 


7 C 


yyyy 


3gggggg00tsss 


[EXTl 


3gggg 


ggee eeee 


[EXTsJ 


399999911 C 


yyyy 


40 


Oddd 




40 


OOff ffff 


[EXT] 


40 


4 Oddd 




40 


Olff ffff 


[EXT] 


40 


8 Oddd 




40 


lOff fflf 


[EXT] 


40 


C Oddd 




40 


llff ffff 


[EXT] 


4ddctt 


8 Orrr 




4ddd110ee eece 


[EXTl 


4ddd1 


B C 


yyyy 


4ddd> lljj liii 


[EXTl 


42 


Oddd 




42 


OOff ffff 


[EXT] 


42 


4 Oddd 




42 


Olff ffff 


[EXT] 


42 


8 Oddd 




42 


lOff ffif 


[EXTl 


44 


Oddd 




44 


OOff ffi* 


[EXT] 


44 


4 Oddd 




44 


Olff fftf 


[EXTl 


44 


8 Oddd 




44 


lOff ffi'l 


[EXT] 


44 


C OsiS 




44 


HeeeEfP 


[EXTl 


44 


F C 


00 yy 


46 


Oddil 




46 


OOff fff 


[EXT] 


46 


4 Oddd 




46 


Olff ff-f 


[EXT] 


46 


8 Oddd 




46 


1 0ff fff 


[EXTl 


46 


C 0&&!. 




46 




[Exn 


46 


F C 


yyyy 


48 


OtJdfi 




48 


OOff fff 


[EXT] 


48 


4 Orir 




48 


01 ii jiij 


[EXTl 


48 


8 Oddd 




48 


lOhhhhlih 


mmmrr 


48 


A Oddd 


kkkk 


48 


C Oddd 




48 


llhUihhh 


mmmm 


48 


E Oddd 


kkkk 


4A 


Orir 




4A 


OOff ff-"f 


[EXTl 


4A 


4 Orri 




4A 


Olff fft 


[EXT] 


4A 


8 Orrr 




4A 


1 0ff ff-f 


[EXTl 


4A 


C Orrr 




4A 


llff fff 


[EXT] 


40 


lOij ijji 


mrnmm 


4C 


A Os-s-s 
E Oh-.i, 


mmmm 


4C 


mmmm 


40 


lljj JiiJ 


mmmm 


40 


E Ossb 


mmmm 


4E 


4 WW 





zzzz 

lEXTJ 
[EXTsl 
zzzz 

[EXTl 



[EXTl 
[EXTl 

[EXTgl 

[EXTl 
(EXTl 
[EXTl 
[EXTl 
[EXTl 
[EXTl 
[EXTl 
[EXTl 
[EXTl 
[EXT] 
[EXTl 
[EXT] 
[EXT] 
[EXTl 

[EXTl 
[EXTl 
[EXTl 
[EXTl 

[EXTl 
[EXTl 
[EXTl 

[EXTl 

[EXT] 

[EXT] 

[EXTl 

[EXTl 
[EXTl 

[EXTl 



[EXTjl 
[EXTl 



[EXTjl 
(EXTl 



[EXTdl 
(EXTl 



(EXTdl 



[EXT] 
[EXT] 



[EXTl 
[EXT] 
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Table 7-8. MC68000 Object Codes in Numerical Order (Continued) 



Byte 1 Byte 2 Byte 3 Byte 4 Byte 5 Byte 6 Byte 7 Byte 8 Byte 9 Byte 10 



5 Orrr 

5 Irrr 

6 Osss 

6 1SS5 



lOjj jjij 

iijjiiii 

5 bbbO Oddd 
SbbbOOOffffff 
SbbbO 4 Oddd 
SbbbO 4 Iddd 
5bbb0 01ffffff 
SbbbO 8 Oddd 
SbbbO 8 Iddd 
SbbbOOIffffff 
50 C Oddd 
50 C Irrr 
50 1 1 ff ffff 
5 bbbi Oddd 
5bbbl00ffffff 
5 bbbi 4 Oddd 
5 bbbi 4 Iddd 
5 bbbi 01 ff ffff 
5 bbbi 8 Oddd 
5 bbbi 8 Iddd 
5 bbbi 01 ff ffff 



51 
51 
51 
52 
52 
52 
53 
53 
53 
54 
54 
54 
55 
55 
55 
56 
56 
56 
57 
57 
57 
58 
58 
58 
59 
59 
59 
5A 
5A 
5A 
5B 
5B 
5B 
5C 
5C 
5C 
5D 
5D 
5D 
5E 
5E 



C Oddd 
C Irrrr 
1 f f ffff 
C Oddd 
C 1 rrrr 
1 ff ffff 
C Oddd 
C Irrr 
Iff ffff 
C Oddd 
D Irrr 
Iff ffff 
C Oddd 
C Irrr 
Iff ffff 
C Oddd 
C Irrr 
Iff ffff 
C Oddd 
C 1 rrrr 
Iff ffff 
C Oddd 
C Irrr 
Iff ffff 
C Oddd 
C Irrr 
Iff ffff 
C Oddd 
C Irrr 
Iff ffff 
C Oddd 
C Irrr 
Iff ffff 
C Oddd 
C Irrr 
Iff ffff 
C Oddd 
C Irrr 
Iff ffff 
C Oddd 
C Irrr 



[EXT] 
[EXT] 



lEXTl 



lEXTl 



[EXTl 



xxxx 

[EX 11 



lEXTl 



[EXT] 



[EXTl 



xxxx 
[EXTl 



xxxx 
[EXTl 



xxxx 
[EXTl 



xxxx 
[EXT] 



xxxx 
[EXT] 



xxxx 
[EXT] 



xxxx 
[EXTl 



xxxx 
[EXTl 



xxxx 
[EXTl 



xxxx 
[EXTl 



xxxx 
[EXTl 



xxxx 
[EXT] 



xxxx 
[EXTl 



[EXTl 
[EXTl 

[EXTl 

[EXT] 

lEXTl 

[EXTl 
[EXT] 

[EXTl 

[EXTl 

[EXTl 

[EXT] 

[EXT] 

[EXT] 

[EXTl 

[EXTl 

[EXTl 

[EXT] 

[EXTl 

[EXT] 

[EXT] 

lEXTl 

(EXTl 





nstruction 


LINK 


An,d16 


UNLK 


An 


MOVE 


An.USP 


MOVE 


USP.An 


RESET 




NOP 




STOP 


data 16 


RTE 




RTS 




TRAPV 




RTR 




JSR 


jadr 


JMP 


jadr 


ADDOB 


dataS.Dn 


ADDQ.B 


dataS.dadr 


ADDOW 


data3,Dn 


ADDQ.W 


data3,An 


ADDOW 


dataS.dadr 


ADDQ.L 


dataS.Dn 


ADDQ.L 


dataS,An 


ADDQL 


dataS.dadr 


ST 


Dn 


DBT 


Dn.label 


ST 


dadr 


SUBQ.B 


dataS.Dn 


SUBQ.B 


dataS.dadr 


SUBQ.W 


dataS.Dn 


SUBO.W 


dataS.An 


SUBO.W 


dataS.dadr 


SUBCL 


dataS.Dn 


SUBCL 


dataS.An 


SUBQ.L 


dataS.dadr 


SF 


Dn 


DBF 


Dn.label 


SF 


dadr 


SHI 


Dn 


DBHI 


Dalabel 


SHI 


dadr 


SLS 


Dn 


DBLS 


Dn.label 


SLS 


dadr 


SCO 


Dn 


DBCC 


Dn.label 


SCO 


dadr 


SCS 


Dn 


DBCS 


Dn,label 


SCS 


dadr 


SNE 


Dn 


DBNE 


Dn,label 


SNE 


dadr 


SEQ 


Dn 


DBEQ 


Dn.label 


SEQ 


dadr 


SVC 


Dn 


DVC 


Dn.label 


SVC 


dadr 


SVS 


Dn 


DVS 


Dn.label 


SVS 


dadr 


SPL 


Dn 


DBPL 


Dn.label 


SPL 


dadr 


SMI 


Dn 


DBMI 


Dn.label 


SMI 


dadr 


SGE 


Dn 


DBGE 


Dn.label 


SGE 


dadr 


SLT 


Dn 


DBLT 


Dn.label 


SLT 


dadr 


SGT 


Dn 


DBGT 


Dn.label 
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Table 7-8. MC68000 Object Codes in Numerical Order (Continued) 



Byte 1 Byte 2 Byte 3 Byte 4 Byte 5 Byte 6 Byte 7 Byte 8 Byte 9 Byte 10 





Instruction 


SGT 


dadr 


SLE 


Dn 


DBLE 


Dn.label 


SLE 


dadr 


BRA 


label 


BRA 


label 


BSR 


label 


BSR 


label 


BHI 


label 


BHI 


label 


BLS 


label 


BLS 


label 


BCC 


label 


BCC 


label 


BCS 


label 


BCS 


label 


BNE 


label 


BNE 


label 


BEQ 


label 


BEQ 


label 


BVC 


label 


BVC 


label 


BVS 


label 


BVS 


label 


BPL 


label 


BPL 


label 


BMI 


label 


BMI 


label 


BGE 


label 


BGE 


label 


BLT 


label 


BLT 


label 


BGT 


label 


BGT 


label 


BLE 


label 


BLE 


label 


MOVEQ 


dataS.Dn 


OR. B 


sDn.dDn 


OR.B 


sadr.Dn 


OR. W 


sDn.dDn 


OR.W 


sadr.Dn 


OR.L 


sDn.dDn 


OR.L 


sadr.Dn 


DIVU 


sDn.dDn 


DIVU 


sadr.Dn 


DIVU 


dataie.Dn 


SBC 


sDn.dDn 


SBCD 


-(sAn),-(dAn) 


ORB 


Dn.dadr 


OR.W 


Dn.dadr 


OR.L 


Dn.dadr 


DIVS 


sDn.dDn 


DIVS 


sadr.Dn 


DIVS 


data16,Dn 


SUB.B 


sDn.dDn 


SUB.B 


sadr.Dn 


SUB.W 


rs.Dn 


SUB.W 


sadr.Dn 



5E 


Iff ffff 


[EXTj 


5F 


C Oddd 




5F 


C Irrr 


xxxx 


5F 


lift ffff 


[EXT] 


60 





xxxx 


60 


XX 




61 


00 


xxxx 


61 


XX 




62 


00 


xxxx 


62 


XX 




63 


00 


xxxx 


63 


XX 




64 


00 


xxxx 


64 


XX 




65 


00 


xxxx 


65 


XX 




66 


00 


xxxx 


66 


XX 




67 


00 


xxxx 


67 


XX 




68 


00 


xxxx 


68 


XX 




69 


00 


xxxx 


69 


XX 




6A 


00 


xxxx 


6A 


XX 




6B 


00 


xxxx 


6B 


XX 




60 


00 


xxxx 


60 


XX 




6D 


00 


xxxx 


6D 


XX 




6E 


00 


xxxx 


6E 


XX 




6F 


00 


xxxx 


6F 


XX 




7dddO 


VV 




SdddO 


OsES 




SdddOOOeeeeee 


[EXT] 


SdddO 
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THE 2901, 2901 A, AND 2901 B MICROPRO 

The 2901, 2901 A, and 2901 B are identical except for execution speeds. The 

than the 2901 ; the 2901 B is about 25% faster than the 2901 A, For details see the d< 

The 2901 provides a 4-bit slice through the arithmetic and logic unit of a Cent 
the Central Processing Unit's registers may also be generated out of 2901 U 

Figures 8-1 and 8-2 functionally illustrate 2901 logic. 

Figure 8-1 is a variation of Figure 4-3 from Volume 1 ; it illustrates 2901 logic 
description given in Chapter 4 of Volume 1 . Figure 8-2 is a more accurate repr 
paths. Note that all logic and data paths in Figure 8-2 are four bits wide. 

2901 logic consists of an arithmetic and logic unit, a local, two-part read/write mer 
and logic unit perfornns addition, subtraction, and the standard Boolean operati 
receives two inputs and generates one output. The local read/write mennory stor« 
results. In addition to the local read/write memory there is a "Q register" which is 
double-length operations. You may compare the 2901 's 16 registers to a CPU v\ 
usually implement a CPU's accumulator in the Q register, and you may or may not i 
registers in local RAM (in general, however, you will implement these registers in 

You will frequently see obvious parallels between 2901 logic and CPU logic. You i 
understand 2901 logic; however, do not assume that these parallels translate intc 

The many data paths within the 2901 have been selected to link the ALU, local read 
output in a functionally efficient manner. Shift logic has been inserted at selected 
combination of data paths with ALU and shift logic minimizes the number of steps n 
cessing Unit functions. 

The few 2901 enhancements over the prior 6701 were designed specifically to redi 
implement typical CPU operations; and these few enhancements were sufficient t 

2901 MICROPROCESSOR SLICE PINS AND SIGNALS 

Pins and signal assignments for the 2901 are illustrated in Figure 8-3. We will 
each of these signals superficially before examining device operations in detail. 

We may divide 2901 signals into these three categories: 

1) Control inputs that are generated by a microinstruction 

2) Control signals connecting 2901 slices 

3) Data and status outputs 

First consider microinstruction-generated inputs. 

A0-A3 and B0-B3 are two 4-bit addresses which select locations within the 29 

10-18 is a 9-bit instruction code which determines data flow and arithmetic/logic; 
9-bit control code can be divided into three 3-bit fields as follows: 




Bit No. 
Instruction co( 



ALU source id 
ALU operation 
ALU destinatic 
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Chapter 8 
2900 SERIES CHIP SLICE PRODUCTS 

Chip slice products represent a radical departure from the single-chip Central Processing Units that we have de- 
scribed up to this point. Chip slice products are, in fact, the building blocks for many Central Processing Units; they 
are also used to build intelligent controllers. 

There are a variety of chip slice- type products on the market today; however, the 2900 series products are the 
clear leaders in terms of sales and customer acceptance. The 2900 series is an enhancement of the older 6700 
series chip slice products, which are not described since they are now obsolete. 

Chip slice products are described conceptually in Chapter 4 of Voume 1 (in fact, the "general case" product de- 
scribed in Volume 1, Chapter 4 is a thinly disguised variation of the 2901 microprocessor slice). Therefoer, the 
discussion which follows assumes that you have a conceptual understanding of chip slice devices and 
microprogramming. If you do nto have this background, see Chapter 4 of Volume 1 before reading any further. 

in this chapter we will describe the following 2900 series parts: 

' The 2901, 2901 A, and 2901 B microprocessor slices 

• The 2902A Look-Ahead Carry Generator 

• The 2903 Enhanced Microprocessor Slice 

• The 2909A, 2910, and 291 1A Microprogram Sequencers 

• The 2930 and 2932 Program Control Units 

All 2900 series devices use bipolar LSI technology. 2900 series microinstruction execution times vary with manufac- 
turer and device. Consult the data sheets at the end of this chapter for details. 

The primary source for the 2900 series chip slice products is: 

ADVANCED MICRO DEVICES 

901 Thompson Place 
Sunnyvale, California 94086 

Secondary sources for the 2900 series include: 

MOTOROLA SEMICONDUCTOR 

Box 20912 

Phoenix, Arizona 85036 

RAYTHEON SEMICONDUCTOR 

350 Ellis Street 

Mountain View, California 34042 

NATIONAL SEMICONDUCTOR 

2900 Semiconductor Drive 
Santa Clara, California 95050 

FAIRCHILD CAMERA & INSTRUMENT CORPORATION 

464 Ellis Street 

Mountain View, California 94042 
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THE 2901, 2901 A, AND 2901 B MICROPROCESSOR SLICE 

The 2901, 2901 A, and 2901 B are identical except for execution speeds. The 2901 A is approximately 30% faster 
than the 2901 ; the 2901 B is about 25% faster than the 2901 A. For details see the data sheets at the end of this chapter. 

The 2901 provides a 4-bit slice through the arithmetic and logic unit of a Central Processing Unit. Some or all of 
the Central Processing Unit's registers may also be generated out of 2901 logic. 

Figures 8-1 and 8-2 functionally illustrate 2901 logic. 

Figure 8-1 is a variation of Figure 4-3 from Volume 1 ; it illustrates 2901 logic in terms of the general chip slice 
description given in Chapter 4 of Volume 1 . Figure 8-2 is a more accurate representation of 2901 logic and data 
paths. Note that all logic and data paths in Figure 8-2 are four bits wide. 

2901 logic consists of an arithmetic and logic unit, a local, two-part read/write memory, and shift logic. The arithmetic 
and logic unit performs addition, subtraction, and the standard Boolean operations. The arithmetic and logic unit 
receives two inputs and generates one output. The local read/write memory stores data, which may be operands or 
results. In addition to the local read/write memory there is a "Q register" which is used as a temporary register or for 
double-length operations. You may compare the 2901's 16 registers to a CPU with 16 accumulators. You will not 
usually implement a CPU's accumulator in the Q register, and you may or may not implement a CPU's general purpose 
registers in local RAM (in general, however, you will implement these registers in local RAM). 

You will frequently see obvious parallels between 2901 logic and CPU logic. You may use these parallels to help you 
understand 2901 logic; however, do not assume that these parallels translate into CPU implementation. 

The many data paths within the 2901 have been selected to link the ALU, local read/write memory, data input and data 
output in a functionally efficient manner. Shift logic has been inserted at selected points along data paths so that the 
combination of data paths with ALU and shift logic minimizes the number of steps needed to create typical Central Pro- 
cessing Unit functions. 

The few 2901 enhancements over the prior 6701 were designed specifically to reduce the number of steps required to 
implement typical CPU operations; and these few enhancements were sufficient to render the 6701 obsolete. 

2901 MICROPROCESSOR SLICE PINS AND SIGNALS 

Pins and signal assignments for the 2901 are illustrated in Figure 8-3. We will summarize functions performed by 
each of these signals superficially before examining device operations in detail. 

We may divide 2901 signals into these three categories: 

1) Control inputs that are generated by a microinstruction 

2) Control signals connecting 2901 slices 

3) Data and status outputs 

First consider microinstruction-generated inputs. 

A0-A3 and B0-B3 are two 4-bit addresses which select locations within the 2901 local 16 X 4 bit RAM. 

10-18 is a 9-bit instruction code which determines data flow and arithmetic/logical operations within the 2901. This 
9-bit control code can be divided into three 3-bit fields as follows: 

Bit No. 
Instruction code 

ALU source identifier 
ALU operation Identifier 
•ALU destination identifier 
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Data In 



4-bit wide shifter 



-4 bits wide 




Data Out 



16x4 bits of 
unassigned 
D Register Blocl< 



A (Direct connection from A-A to Y-Y) 



4-bit wide 
Complementer, 
Addition and 
Boolean logic 
(ALU Block) 



4-bit wide shifter 



4-bit wide 
Buffer Register 



Figure 8-1. The 2901 Microprocessor Slice 
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Figure 8-2. 2901 4-Bit Slice Logic 
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RAMO 

(+5V) Vcc 

F 




Pin Name 


Description 


Type 


DO - D3 


Data input 


Input 


YO- Y3 


Data output 


Output, Tristate 


OE 


Output enable 


Input 


AO- A3 


Local RAM A address 


Input 


BO- B3 


Local RAM B address 


Input 


10-18 


Instruction code 


Input 


RAMO, RAMS 


Local RAM shift logic I/O 


Bidirectional 


QO, Q3 


Q register shift logic I/O 


Bidirectional 


CN 


Carry in 


Input 


C (N+4) 


Carry out 


Output 


G, P 


Carry generate/propagate 


Output 


F 


Zero status 


Output, Open collector 


F3 


Sign status 


Output 


OVR 


Overflow status 


Output 


CP 


Clock 


Input 


Vcc- GND 


Power, ground 





Figure 8-3. 2901 A Microprocessor Slice Pins and Signal Assignnnents 
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D0-D3 is a data input port. All data entering a 2901 must be input via D0-D3. We include these four pins among the 
microinstruction-generated group since a microinstruction could indeed generate immediate data (in macro assenribly 
language terms) to be input via D0-D3. A more common alternative might be to generate this data out of an external 
buffer, using microinstruction bits to enable a single output as follows: 




DO - D3 



OE is an output enable control. When OE is low, the 2901 can output data via Y0-Y3. When OE is high, Y0-Y3 is 
fl£ated. A microinstruction must anticipate microcycles within which data output is to occur and must generate a low 
OE control at this time. When no data output is anticipated Y0-Y3 should be floated. 

Let us now examine data and status output signals. 

As indicated in the previous paragraph, a 2901 outputs the results of internal operations via the four pins Y0-Y3. 
In addition, separate Overflow (OVR) and Zero (F) status indicators are output. These indicators are used to gener- 
ate standard Overflow and Zero statuses — as we will describe later. 

Carry Status logic and associated signals are not simple status outputs; they are more accurately represented as in- 
terslice connecting signals. CN is the carry in used by addition and_subtraction. C(N+4) is the carry out generated 
by addition and subtraction. Carry Look-Ahead logic uses the P and G signals, together with the 2902 Carry 
Generator, in order to compute the carry for an arithmetic operation occurring in parallel at two or more 2901 slices. 
This carry logic has been described in Volume 1, Chapter 4; it is summarized later in this chapter when we describe the 
2902 Carry Look-Ahead Generator. 

The 2901 has two sets of internal shift, logic. For multislice shifts, bits shifted out from one slice must be shifted 
into the adjacent slice. QO and Q3 are the shift pins used by one set of shift logic; RAMO and RAMS are the shift 
pins used by the other set of shift logic. 

CP is the master clock signal used to control and synchronize event sequences within the 2901. 
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2901 LOGIC 

We will now examine 2901 logic in detail. 

The best place to start understanding 2901 logic is at the read/write memory (local RAM): 




RAM3 
RO/LI 



2901 

LOCAL 

RAM 



CLOCK 
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The 2901 local RAM consists of sixteen 4-bit locations. 

You use pins A0-A3 to identify the location from which data will be output to the A latch. This nnay be illustrated as 
follows: 











3 


2 


1 













A3 


A2 


A1 


AoJ 



Microinstruction 




This is the addressed location. 
It contains X-\q, which is output 
to the A latch 
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You use pins B0-B3 to identify the 4-bit location fronn which data will be output to the B latch and into which data from 
the ALU will be written. This may be illustrated as follows: 



Input data = Y 
DO D1 D2 D3 



This Is the addressed location. 
Y can be written into it via 
DO - D3. X can be read out of 
it to the B latch. 




7 6 5 4 3 2 1 



B3 B2 81 80 A3, A2 A1 AO Microinstruction 



2901 MICRO- 
INSTRUCTION 



In the two illustrations above we show the A and B pin inputs coming from eight bits of a 
microinstruction. This data may come from the Instruction register as well. The selected 
microinstruction bit numbers are not significant. 

The same address input at A0-A3 and B0-B3 results in the same data out the A and B latches. 

In order to avoid race conditions which could result if you attempted to read and write at the same time, the 
clock signal CP controls event sequences as follows: 



CP 



J~ 



A and B Latch 



I 



Data changing 



Data stable 



Data changing 



Data stable 



r_: 



Write Location 



:::dc 



Data stable 



Data changing 



Data stable 



Data changing 



In the timing diagram above, the A and B latch will receive data from the local RAM location addressed by the A and B 
address inputs. However, the A and B latch will only receive data from its associated RAM location while CP is high. As 
soon as CP goes low, and A and B latches hold whatever data they contained at the time CP made its high-to-low tran- 
sition. 

Similarly, data at the D0-D3 inputs can be written into the local RAM location addressed by the B address inputs while 
CP is low. While CP is high, the addressed local RAM location will hold whatever data it contained when CP made its 
low-to-high transition; thus, the addresses can be changed. These internal RAM latches cause the RAM to appear to 
the user as a (low-to-high) edge-triggered RAM. 
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The 2901 local RAM generates a 4-bit word through selected programmable registers of a 2901 RAM 

Central Processing Unit. But these sixteen local RAM locations do not represent the only place AND CPU 

where CPU registers can be created; that would limit you to a connbined total of sixteen progrann- REGISTERS 
nnable registers — which is frequently insufficient. 

Using register terminology from Chapters 6 and 7 of Volume 1, Primary Accumulators will most likely occupy 2901 
local RAM locations; this is because Primary Accumulators are frequent sources and destinations for data operated on 
by the arithmetic and logic unit. 

Secondary Accumulators may or may not occupy 2901 local RAM locations. Certainly if there are spare local RAM loca- 
tions it would make sense to allocate these to Secondary Accumulators, or fixed, "non-programmable" constants. But if 
there are no spare local RAM locations, then Secondary Accumulators could easily occupy external read/write memory. 
A 2901 can access external memory to read or write data, but this has some associated restrictions — which are de- 
scribed later in this chapter when we examine the 2903. 

Central Processing Unit registers that are normally used to compute memory addresses for the macroprogram may or 
may not occupy 2901 RAM space. To the 2901 ALU, there is no difference between computing an address, or data. 
Adding an Index to a base address is the same as adding the contents of two Accumulators;- both are simple addition. 

For a simple Central Processing Unit, address registers are likely to be located in the 2901 local RAM; then memory ad- 
dress computations and data computations must occur sequentially. In more complex Central Processing Units, you 
will compute assembly language memory addresses using one of the special memory addressing devices — the 2930 
or the 2932. These devices contain their own registers; also, they compute memory addresses while the 2901 is per- 
forming ALU operations in parallel. Alternatively, the designer may choose to use a second set of 2901 s to build a high- 
speed memory addressing unit. 

In the preceding discussion we used the term "macroprogram memory address" to identify computer memory, in con- 
trast to memory within Central Processing Unit logic, where microinstructions are stored. If you are confused by the 
difference between a macroinstruction memory address and a microinstruction memory address, refer again to Chapter 
4 of Volume 1. 

If a memory address register, such as an Index register, is also to serve as a general purpose Accumulator, it will have to 
be located in the 2901 local RAM, or in the external memory that accommodates Secondary Accumulators. 

The Instruction register will almost never be housed in local 2901 RAM. The macroinstruction object code will be held 
in an external buffer (the Instruction register) whose contents are decoded by logic external to the 2901 in order to trig- 
ger execution of appropriate microinstruction sequences. We will describe this logic later. 

The D0-D3 inputs to the local RAM come from a 3-IN MUX. The 3-iN MUX receives the arithmetic and logic unit 
output, which it can shift up or down one bit position. The shift is achieved by connecting each ALU output line to 
three local RAM inputs. The RAMO and RAM3 pin connections of the 2901 allow you to cascade 2901 slices so that an 
up or down shift can be propagated through eight, twelve, sixteen, or more bit positions. 

Beginning at the 4-bit level, we can illustrate logic for unshifted local RAM input as follows: 



RAMO 



DO = FO 



D1 =F1 



D2 = F2 



I 9 RAM3 




D3 = F3 
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Data shifted up one bit receives a new low-order bit from RAMO and outputs the high-order ALU product bit via RAM3 
as follows: 



RAMO' 



-^>* 



t--.-_-.-.-r 



rr 



RAM3 = F3 



I I 
J L 



3-IN 
MUX 



3-IN 
MUX 



I r- 
I I 



3-IN 
MUX 



3-IN 
MUX 



■FO 
■F1 
•F2 
•F3 



DO = RAMO 



D1 =F0 



D2 = F1 



D3 = F2 



Similarly, a 1-bit downshift receives a new high-order bit from RAMS and outputs the low-order product bit via RAMO 
as follows: 



RAMO = FO 



1 



3-IN 
MUX 



D0 = F1 



t=i 



I 



3-IN 
MUX 



D1 =F2 



t-t- 
I I 

J L 



3-IN 
MUX 

~T 

D2 = F3 



^ 



J L 



3-IN 
MUX 



D3 = RAM3 



■RAM3 



■F1 I ALU 
-F2 (output 
■F3) 
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The Q register is a single 4-bit location with 3-IN MUX input logic similar to the local RAM 
input logic which we have just described. Q register logic may be illustrated as follows: 



2901 Q 
REGISTER 
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3-IN 
MUX 




3-IN 
MUX 




3-IN 
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3-IN 
MUX 




























DO D1 D2 D3 

Q Register 
QO Q1 Q2 Q3 






















































1 


1 




■ To ALU Inputs 



Q register logic is used primarily to enable double length up and down shifts which are needed by binary multiply and 
divide logic. Accordingly the Q register 3-IN MUX receives these inputs: 

• The ALU output 

• Its own output - shifted up or down one bit position 

Thus fresh data entering the Q register comes from the arithmetic and logic unit output. Subsequently, this data may 
be shifted up or down any number of bit positions by recycling the Q register output back to the 3-IN MUX input, 
shifted down one bit position: 

QO Q1 Q2 Q3 (Q3) 



///// 

(QO) DO D1 D2 D3 



or shifted up one bit position: 



(QO) QO Q1 Q2 Q3 

DO D1 D2 D3 (Q3) 

The QO and Q3 pin connections serve the same purpose for the Q register shift logic as the RAMO and RAM3 pin con- 
nections serve for local RAM logic. 
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We will now examine the arithmetic and logic unit. Including the following logic from Figure 
8-2: 



2901 ALU 
LOGIC 




These three aspects of ALU logic are important: 

1) The ALU operation which is to be perfornned. 

2) The operands which are input to the ALU. 

3) The destination for the ALU output. Shift logic lies in the path of ALU output data, therefore the destination 
specification includes any shift operation. 

Instruction code bits 10, 11, and 12 control the data input to the 2901 ALU; instruction code bits 13, 14, and 15 
determine the operations which occur within the arithmetic and logic unit. Table 8-1 summarizes 10, 11, and 12 
interpretations, while Table 8-2 summarizes 13, 14, and 15 Interpretations. Table 8-3 shows the result of 10-15 
combinations. 

The two arithmetic and logic unit inputs are generated by a 2-IN MUX and a 3-IN MUX. The 2-IN MUX (which generates 
the R inputs) receives external data, or the A latch outputs from the local RAM. The 3-IN MUX (which generates the S 
inputs) receives the A or B latch outputs from the local RAM, or the Q register output. As an additional option, can be 
inserted at the R or S inputs of the arithmetic and logic unit. Thus the following twelve R and S input combinations 
could be generated. 



R 


- A A A A 


D D D D 







S 


- A B Q 


A B Q 


A B Q 






• 


• • 


. 


Used by 2901 




• * 


* 


* 


Not used by 2901 



A 3-bit input code can specify eight of the twelve input combinations illustrated above. 

A,A is eliminated since it is equivalent to A,B with the same address input at A and B. 

A,0 is eliminated since it is equivalent to 0,A. 

D,B is eliminated since it is equivalent to D,A; remember, the A and B addresses can be the same. 

0,0 is eliminated since you cannot perform a useful arithmetic or logic operation on two zero operands. 
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Table 8-1. 


ALU Source Operand Control 


iVIicro Code 


ALU Source Operands 


12 


11 


10 


Hex 
Code 


R 


S 














A 


Q 








1 


1 


A 


B 





1 





2 





Q 





1 


1 


3 





B 


1 








4 





A 


1 





1 


5 


D 


A 


1 


1 





6 


D 


Q 


1 


1 


1 


7 


D 






Table 8-2. 2901 ALU Function Control 



IVIicro Code 



Hex 
Code 



ALU 
Function 



R Plus S 
S Minus R 
R Minus S 
R OR S 
R AND S 
R ANDS 
R EX-OR S 
R EX-NOR 



Symbol 



R + S 
S-R 
R-S 
R VS 
R A S 
R A S 
R ® S 
R ® S 







Table 8-3. 2901 


Source Ope 


rand and ALU Function Matrix 






\ 

<5 

4 
3 


'210 





1 


2 


3 


4 


5 


6 


7 


\. ALU 
N. Source 

ALU^V 
Function \. 


A,Q 


A,B 


O.Q 


0,B 


O.A 


D,A 


D,a 


D,0 





CN = L 
R Plus S 

CM = H 


A+Q 
A+Q+1 


A+B 
A+B+1 


Q 
Q+1 


B 
B+1 


A 
A+1 


D+A 
D+A+1 


D+Q 
D+Q+l 


D 
D-H 


1 


CN = L 

S Minus R 

CN = H 


Q-A-1 
Q-A 


B-A-1 
B-A 


Q-1 
Q 


B-1 
B 


A-1 
A 


A-D-1 
A-D 


Q-D-1 
Q-D 


-D-1 
-D 


2 


CN = L 

R Minus S 

CN = H 


A-Q-1 
A-Q 


A-B-1 
A-B 


-Q-1 
-Q 


-B-1 
-B 


-A-1 
-A 


D-A-1 
D-A 


D-Q-1 
D-Q 


D-1 
D 


3 


RORS 


A VQ 


A VB 


Q 


B 


A 


D VA 


D VQ 


D 


4 


RANDS 


A AQ 


A A B 











D A A 


D A Q 





5 


RANDS 


A AQ 


A A B 


Q 


B 


A 


DA A 


D A Q 





6 


R EX-OR S 


A ® Q 


A ® B 


Q 


B 


A 


D ® A 


D ® Q 


D 


7 


R EX-NOR S 


A ® Q 


A® B 


Q 


B 


A 


D ® A 


D ® Q 


D 


+ = 


Plus; - = Minus; V 


= OR; A = AND; ® = EX-OR 







The eight ALU operations specified by 13, 14, and 15, combined with operand options, generate more than eight effec- 
tive operations. If you look at Table 8-3 you will see that you can increment, decrement, complement or negate data; 
you can simply pass data through the ALU, or you can generate a zero ALU output. Any of the functions shown in Table 
8-3 can become an ALU output. You have the option of shifting these functions up or down one bit position. 

Instruction bits 16, 17, and 18 select the destination for ALU output, plus any shift which will be performed on 
the ALU output. Table 8-4 summarizes the eight destination options. 
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Table 8-4. ALU Destination Control 



Micro Code 


RAM 
Function 


Q Register 
Function 


Y 
Output 


RAM 
Shifter 


Q 
Shifter 


18 


17 


16 


Hex Code 


Shift 


Load 


Shift 


Load 


RAMO 


RAMS 


QO 


Q3 














X 


NONE 


NONE 


F — Q 


F 


X 




X 


X 


X 








1 


1 


X 


NONE 


X 


NONE 


F 


X 




X 


X 


X 





1 





2 


NONE 


F — B 


X 


NONE 


A 


X 




X 


X 


X 





1 


1 


3 


NONE 


F-B 


X 


NONE 


F 


X 




X 


X 


X 


1 








4 


DOWN 


F/2 — B 


DOWN 


Q/2 — Q 


F 


FO 




INS 


QO 


INS 


1 





1 


5 


DOWN 


F/2-B 


X 


NONE 


F 


FO 




INS 


QO 


X 


1 


1 





6 


UP 


2F — B 


UP 


20 — 


F 


INO 




F3 


INO 


OS 


1 


1 


1 


7 


UP 


2F — B 


X 


NONE 


F 


INO 




F3 


X 
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X = Don't care. Electrically, the shift pin is a TTL Input 

is in the high impedance state. 
B = Register addressed by B inputs. 
Up is toward MSB, Down is toward LSB. 


internally connected to 


a three-state output which 







Because these options are not self-evident, tliey are illustrated in Figures 8-4 through 8-11. 

Yo u will note that most destination codes generate a Y output, in many cases you will not wish to use this output. The 
OE control input, if high, disables the Y output — in which case ALU output does not appear at the Y pins. 

The primary purpose of destination code 0, illustrated in Figure 8-4, is to load the Q register. 

Destination code 1 generates a Y output only. In this case the OE control input will be low. 

Destination code 2, illustrated in Figure 8-6, is a little unusual. This code outputs data directly from local RAM to the Y 
pins; simultaneously the ALU output is loaded into local RAM. If the Program Counter is one of the sixteen general pur- 
pose registers, this code is used to load the Memory Address register and simultaneously update the Program Counter 
to point to the address of the next instruction. 

Destination code 3, illustrated in Figure 8-7, loads ALU outputs into local RAM, and transmits ALU outputs to the Y 
pins. 

Destination codes 4, 5, 6, and 7, illustrated in Figures 8-8 through 8-1 1, are quite similar. These four codes output 
the ALU product at the Y pins and load this product into local RAM. Codes 4 and 6 also transfer Q register output back 
as Q register input. Codes 4 and 5 generate downshifts at the local RAM and Q register inputs, while codes 6 and 7 
generate upshifts at the local RAM and Q register inputs. 
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Figure 8-4. 2901 Destination Code Data Paths 
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Figure 8-5. 2901 Destination Code 1 Data Paths 
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Figure 8-6. 2901 Destination Code 2 Data Paths 
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Figure 8-7. 2901 Destination Code 3 Data Paths 
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Figure 8-8. 2901 Destination Code 4 Data Paths 
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Figure 8-9. 2901 Destination Code 5 Data Paths 
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Figure 8-10. 2901 Destination Code 6 Data Paths 
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Figure 8-11. 2901 Destination Code 7 Data Paths 
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Let us now examine status logic of the 2901 . You can generate Zero, Sign, Overflow and 
Carry statuses. The Zero, Sign and Overflow statuses are easy to understand, so we will 
look at them first. 

Every 2901 generates an Overflow status at the OVR pin. This status is the exclusive-OR of ca- 
rries out of the penultimate bit and the high-order bit. This nnay be illustrated as follows: 

3 2 10 "^ Bit No. 



C3 C2 



C2 = Carry from bit 2 to bit 3 
C3 = Carry out of bit 3 

OVR = C2 03 



2901 

STATUS 

LOGIC 



2901 

OVERFLOW 

STATUS 



Every 2901 generates an Overflow status; however, in a multi-2901 configuration only the high-order (or most signifi- 
cant) 2901 Overflow status is usually used. Lower-order 2901 Overflow status outputs can be ignored. For an 8-bit con- 
figuration this may be illustrated as follows: 



High-order 
2901 



Low-order 
2901 



-Bit No. 



KJKJ \iJKJ 



High-order OVR 
becomes CPU status 



Ignore low-order 
OVR 



I 

The Sign status which is output at pin F3 is the level of the high-order ALU output bit. Like the 
Overflow status, the Sign status is output by every 2901 in a multislice configuration; however, 
only the high-order 2901 Sign status is significant. For an 8-bit configuration this may be illus- 
trated as follows: 



High-order 
2901 



Low-order 
2901 



] \ 



F3 = level 

of bit 7. 

Use as CPU 

sign status 



F3 = level 
of bit 3. 



■ Bit No. 



2901 
SIGN 
STATUS 



The Zero status is the NOR of the four ALU output lines, FO, F1, F2, and F3. If all four of these 
outputs are 0, then the Zero status output is 1. The Zero status is an open collector signal; 
therefore in multislice configurations Zero status outputs can be wire-ANDed. The AND of all Zero 
status outputs in_ a multi-2901 configuration generates the Zero status for the CPU 
(Zero = FO • F1 • F2 • etc.). 



2901 
ZERO 
STATUS 



2901 Carry status logic is not straightforward because in a multi-2901 configuration an arithmetic 2901 

operation (such as addition) should occur in parallel at each slice; but the carry from a low-order CARRY 

slice will not be generated in time to be accounted for by a parallel operation occurring at a high- STATUS 

er-order slice. This problem has been described in detail in Chapter 4 of Volume 1, therefore we 
will not dwell on it at this time. For now it suffices to note that you can use the CN and C(N-f-4) pins of a 2901 to 
generate carry if you allow ample time between clock cycles for the carry to ripple up through the slices. But if you 
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want to perform the entire arithmetic operation optimally, you must use the propagate (P) and generate (G) signals, in 
addition to CN and C(N+4). These signals are processed by the 2902 Carry Look-Ahead device, which is described 
later in this chapter. 

Table 8-10,_given in the 2902 Carry Lool<-Ahead device discussion, summarizes the exact logic used by the 2901 to 
generate P, G, CN and C(N+4). 

The 2901 can generate a Half-Carry status. The Half-Carry status is needed by microprocessors 
that use binary arithmetic with decimal adjust to generate binary coded decimal logic. In an 8-bit 
configuration the C(N-l-4) output from the low-order 2901 becomes the Half-Carry status. 

SOME 2901 OPERATIONS 

In order to illustrate 2901 logic in action, we will now show how various operations can be 
performed for a Central Processing Unit created using two 2901 slices. We will show the 
microcode for each operation, based on the following 34-bit microinstruction code: 



2901 
HALF- 
CARRY 
STATUS 



2901 

SAMPLE 

MICROCODE 



11XX10000000XOXXXX X X X X X X X XBBBBAAAA 
21 20 IF 1E ID 1C 1B 1A 19 18 17 16 15 14 13 12 11 10 OF OE OD OC OB OA 09 08 07 06 05 04 03 02 01 00 
CYCXS1S0OEI8 17 16 15 14 13 12 11 10 T1 TO Ml MO DH3DH2 DH1 OHO DL3 0L2 DL1 DLO 83 82 B1 BO A3 A2 A1 AO 



-Microinstruction bit 



"T 



-Local RAM A address 
-Local RAM B address 
-Low-order 2901 immediate data in 
..High-order 2901 immediate data in 
-Source select 
- Immediate data from microcode 

1 - Data from buffer 1 

1 - Data from buffer 2 
1 1 - Data from buffer 3 

-Destination select (Four arbitrary destinations) 
-Instruction code 
- Output enable 
-Shift/rotate logic control 
-Carry in control 
- in 

1 - 1 in 

1 - source 1 in 
1 1 - source 2 in 



The fields of the illustrated microinstruction are all self-evident, and have been described in the preceding text, with 
the exception of CY, CX, SI and SO. These four bits are used by shift and rotate logic, which we are about to describe. 
Note that all fields, with the exception of the immediate data fields, are shared by the two 2901 devices. This is 
because 2901 devices operate in parallel and must perform identical operations at any instant. The immediate 4-bit 
data fields differ since an 8-bit data field is unlike 4-bit halves. 

Consider shift and rotate logic (in macroprogram terms) for one or more 2901 slices. Figure 
22-12 shows one possibility using 25LS253 Dual 4 Input Multiplexers to select the correct con- 
nections for RAMO, RAMN, QO, and QN. We refer to the high-order pins as "QN" and "RAMN" 
since one or more slices may be present. For a single slice, RAMN and QN would become RAM3 
and Q3, respectively. For two 2901 slices, RAMN and QN would beciome RAM7 and 07, respectively 

The key to Figure 8-16 lies in the 17 signals which are input to the 1G and 2G pins of the 25LS253 device. Recall that 
17 is one of three control signals input to the 2901 destination control logic. 17 controls shift logic at the local RAM and 
Q register 3-lN MUX inputs. 17 is always high when a downshift occurs. 17 is always low when an upshift occurs. Thus 
in Figure 8-12, 17 conditions one 25LS253 device to output data, while disabling the other device. 



2901 SHIFT 
AND ROTATE 
OPERATIONS 
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Figure 8-12. 2901 Shift and Rotate Logic 



Shifts do not always occur at the 2901 local RAM or Q register inputs (see Figures 8-4 through 8-11). But that is not 
a problenn. If the low-order to high-order 25LS253 device is enabled by 17, but no shift is to occur, then the 2901 will ig- 
nore the active 25LS253 output. 

When a shift is specified by 16, 17, and 18, then the SO and SI inputs control the output of the selected 25LS253 device 
— which determines the kind of shift or rotate that will occur. 

In this discussion of shifts and rotates, the sense of a "left" or "right" shift can cause confusion since all vendor 
2900 literature illustrates bit positions from right to left: 
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We have elected to make our illustrations compatible with vendor literature so that you will have less trouble connect- 
ing descriptions of the same parts. But in macro assembly language terms a left shift normally implies multiplication: 
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while a right shift implies division: 
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Given the bit numbering system used by 2900 vendor literature, the opposite shift logic would apply. That is to say, a 
left shift would become a divide: 
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while a right shift becomes a multiply: 
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In order to avoid confusion, we shall refer to "upshifts" and "downshifts". An "upshift" causes multiplication, 
while a "downshift" causes division. An upshift becomes a left shift in macrolanguage terms, but looks like a right shift 
in 2900 vendor literature, and in the illustrations of this chapter. A downshift becomes a right shift in macrolanguage 
terms, but looks like a left shift in 2900 vendor literature, and in the illustrations of this chapter. We have elected to live 
with this confusion since it is smaller than the confusion which would arise if all our 2900 series part descriptions in- 
verted bit numbers and data flows with respect to vendor literature. 

Beginning with the simplest case, consider a simple downshift where zero is loaded into the high-order bit and the low- 
order bit is lost. In effect the number has been divided by two. 

Figure 8-13 illustrates a downshift occurring in local RAM only. 17 is-low, therefore the right-most 25LS253 device 
(as illustrated in Figure 8-13) is enabled, while the left-most 25LS253 device is disabled. SO and SI are both low, 
therefore ICO is output at 1Y and 2C0 is output at 2Y. Thus is loaded into RAMN — and it is assumed that the three 
bits 16, 17, and 18 cause the downshift to occur at the local RAM 3-IN MUX logic. 

Note that a Q downshift will occur in Figure 8-13 at the same time as the local RAM downshift — if 16, 17, and 18 codes 
have enabled the Q register 3-IN MUX downshift logic. For clarity we have not shown both downshifts occurring. 

Were 17 high, then in Figure 8-13 an upshift would occur with loaded into RAMO, and thence DO. 

When executing a down- or upshift, as illustrated in Figure 8-13, you could shift in 1, rather than 0, by inputting SO 
high and SI low. This causes 1C1 to be output at 1Y and 2C1 to be output at 2Y. 

Next consider a down rotate; this operation is illustrated in Figure 8-14. 

The only difference between the down rotate illustrated in Figure 8-14 and the downshift illustrated in Figure 8-13 is 
the source for the Y2 output. A high input at SI with a low input at SO causes 1C2 to be output at 1Y and 2C2 to be 
output at 2Y. 1C2 and 2C2 receive their inputs from QO and RAMO of the low-order 2901, respectively; hence a down 
rotate is achieved. 
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Figure 8-13. A 2901 Downshift 
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Figure 8-14. A 2901 Down Rotate 



You can generate an up rotate by inputting 17 high — which disables the right-most 25LS253 (as illustrated in Figure 
8-14) and enables the left-most 25LS253. 

We need to stress again the fact that 17 has been chosen to enable the left-most 25LS253 when high, and the right- 
nnost 25LS253 when low, because this conforms to the way in which shift logic within the 2901 is controlled. 

Let us now examine arithmetic shifts. The difference between an arithmetic shift and a logical shift lies in the high- 
order bit of a binary number, which arithmetic shift logic treats as a sign bit; the sign bit must be excluded from the 
shift. For arithmetic shifts the logic illustrated in Figure 8-12 concatenates local RAM with the Q registers to generate 
a double length number. For two 2901 slices this may be illustrated as follows: 

Higti-order i Low-order 
2901 I 2901 




Local bit number 
Q register 
< Overall bit number 



Sign bit 



When an arithmetic downshift occurs, the high-order ALU output bit — which is the signed bit — is recycled back to 
RAMN, thus ensuring that it is preserved through the downshift. The remainder of the arithmetic number is shifted 
down one bit position, with the low-order local RAM bit (output via RAMO) becoming the high-order Q register bit (via 
QN). This may be illustrated as follows: 
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As illustrated in Figure 8-12, an arithmetic downshift is generated by 17=0, S0=1 and S1=1. 
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An arithmetic upshift causes to be shifted into QO while QN, the high-order Q register bit, is shifted into RAMO. This 
nnay be illustrated as follows: 
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Note that this arithmetic upshift does not preserve the high-order sign bit. Therefore the arithmetic upshift is really a 
double length logical upshift. 

You can easily generate double length down and up logical rotates by concatenating the Q registers with the local 
RAM. Connect the 1C3 input of the left side 25LS253 device to the RAMN output. Connect the 2C3 input of the left 
side 25LS253 device to the QN output. Connect the 1C3 input of the right side 25LS253 device to the RAMO output. 
Connect the 2C3 input of the right side 25LS253 device to the QO output. 

All of the shift and rotate logic functions we have just described, as well as the Status register and carry-in multiplexer, 
are contained in the 2904 Status and Shift Control Unit. This device eliminates most of the MSI, such as the two 
25LS253S around the 2901s. 
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Let us now look at the simple problem of loading data into a local RAM location. If the data is 
immediate — that is to say, if it is provided by the microinstruction itself — then the following 
single microinstruction will load eight bits of data into the local RAM location addressed by the B 
address: 



2901 

DATA INPUT 




XXXXX011011111XXO0 D D D D D D D DBBBBXXXX 
21 20 IF IE ID 1C IB 1A 19 18 17 16 15 14 13 12 11 10 OF OE OD OC OB OA 09 08 07 06 OS 04 03 02 01 00 
CYCXS1S00EI8 17 16 15 14 13 12 II 10 T1 T0M1 MO DH3DH2 DH1 DH0DL3 DL2 DL1 DUO B3 B2 B1 80 A3 A2 A1 AO 




Output result to RAM 

OR Data with 

Input Data and to ALU 

Select Immediate data 

Data "D" 

RAM location into which data is loaded 



■ Microinstruction bit 



Local RAM A address 

Local RAM B address 

Low-order 2901 immediate data in 

High-order 2901 immediate data in 

Source select 

0- Immediate data from microcode 

1 - Data from buffer 1 

1 - Data from buffer 2 
1 1 - Data from buffer 3 

Destination select (Four arbitrary destinations) 

Instruction code 

Output enable 

Shift/rotate logic control 

Carry in control 

- in 

1 - 1 in 

1 - source 1 in 
1 1 - source 2 in 



If the data which is to be loaded into local RAM comes from an external buffer, and we arbitrarily assume that it comes 
from external data buffer number 2, then the following single microinstruction will transfer the data from external 
buffer 2 to the local RAM location selected by the B address: 




XXXXX011011111XX10 X X X X X X X XBBBBXXXX 
21 20 IF IE ID 1C 1B1A 19 18 17 16 15 14 13 12 11 10 OF OE OD OC 08 OA 09 08 07 06 05 04 03 02 01 00 • 
CYCXS1 SOOE 18 17 16 IS 14 13 12 11 10 T1 T0M1 MO DH3DH2 0H1 DH0DL3DL2DL1 DLO B3 B2 81 80 A3 A2 A1 AO 






Output result to RAM 

OR Data with 

Input Data and to ALU 

Select buffer 2 as data source 

RAM location into which data is loaded 

Don't care 



-Microinstruction bit 



- Local RAM A address 

- Local RAM B address 
-Low-order 2901 immediate data in 
-High-order 2901 immediate data in 

- Source select 

0- Immediate data from microcode 

1 - Data from buffer 1 

1 - Data from buffer 2 
1 1 - Data from buffer 3 

- Destination select (Four arbitrary destinations) 
-Instruction code 

-Output enable 

- Shift/rotate logic control 
-Carry in control 

- in 

1 - 1 in 

1 - source 1 in 
1 1 - source 2 in 
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We described logic associated with microinstruction bits Ml and MO earlier. 

An arithmetic or logic operation performed on two sources taken from local RAM, with the result being output via Y to 
external destination number 1, requires the following single microinstruction: 




C X X X X X X XBBBBAAAA 
21 20 IF 1E ID 1C IB 1A 19 18 17 16 15 14 13 12 11 10 OF OE OD OC OB OA 09 08 07 06 05 04 03 02 01 00- 
CYCXS1S0OEI8 17 16 15 14 13 12 II 10 T1 TO Ml MO DH3DH2 DH1 OHO DL3 DL2 DL1 DLO B3 B2 B1 BO A3 A2 A1 AO 



Output result via Y 

Select ALU operation 

Select A and B latches as ALU operands 

Y output destination select 

Local RAM B address 

Local RAM A address 



- Microinstruction bit 



"d 



- Local RAM A address 

- Local RAM B address 
-Low-order 2901 immediate data in 
-High-order 2901 immediate data in 
-Source select 

- Immediate data from microcode 

1 - Data from buffer 1 

1 - Data from buffer 2 
1 1 - Data from buffer 3 

- Destination select (Four arbitrary destinations) 

- Instruction code 

- Output enable 
-Shift/rotate logic control 

- Carry in control 
- in 

1 - 1 in 

1 - source 1 in 
1 1 - source 2 in 



Now consider the same operation performed on one operand taken from local RAM (as addressed by A), while the other 
operand is provided by the microinstruction as immediate data; the result is returned to the local RAM location ad- 
dressed by B. Here is the necessary microinstruction: 




XXXX1011 I I 110101 00 D D D D D DBBBBAAAA 
21 20 IF IE 1£1C IB 1A19 18 17 16 15 1413 12 11 10 OF OE OD OC OB OA 09 08 07 06 06 04 03 02 01 00 - 
CYCXS1S0OEI8 17 16 15 14 13 12 II 10 T1 TO Ml MO DH3DH2 DH1 DHO DL3 DL2 DL1 DLO 83 82 B1 BO A3 A2 A1 AO 



1 



Disable Y output 

Output ALU result to B 

Specify ALU operation 

Select immediate data and A latch as ALU operands 

Destination select 

Immediate data, second operand 

Result address in local RAM 

Operand address in local RAM 

Don't care 



. Microinstruction bit 



■ Local RAM A address 
' Local RAM B address 

' Low-order 2901 immediate data in 

• High-order 2901 immediate data in 
' Source select 

- Immediate data from microcode 

1 - Data from buffer 1 

1 - Data from buffer 2 
1 1 - Data from buffer 3 

Destination select (Four arbitrary destinations) 
Instruction code 

■ Output enable 

• Shift/rotate logic control 

■ Carry in control 
- in 

1 - 1 in 

1 - source 1 in 
1 1 - source 2 in 
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Two microinstructions, with appropriate looping and select logic, is all you need in order to 
multiply two 8-bit numbers and generate a 16-bit product. The algorithm needed for this 
multiplication initially stores the multiplier in the low-order eight bits of the product space with 
the multiplicand in a separate 8-bit storage location as follows: 



2901 
MULTIPLY 



7 
15 




Product (initial) 
Product (final) 
Product space 
Multiplier (initial) 

Multiplicand 



We are going to downshift the contents of the 16-bit product space eight times. After eight shifts, the multiplier will 
have been shifted out and lost. Therefore the high-order eight bits of the product space will initially be assigned to the 
low-order eight bits of the product, as shown above. 

In the typical "shift" and "add" multiplication routine (which we have described in Volume 1) the multiplicand is 
upshifted one bit position at a time, and is added to the product whenever there is a 1 in the multiplier bit correspond- 
ing to the current upshift. Here is a simple illustration of two 4-bit numbers being multiplied to create an 8-bit product: 

1010'0101=00110010 



Step 1 : 



00000000 
101 



1010 



Step 2: 



0000000 

1010 

0000 1010 



1 oro 



Step 3: 



0000 10 10 
10 100 



1010 



Step 4: 



0000 10 10 

010 1 000 

00110010 



1010 



The multiplicand initially corresponds to the low-order multiplier bit. The multiplicand is subsequently upshifted three 
times, corresponding to the three higher-order multiplier bits. Following the first and third upshift, the multiplicand is 
added to the product, since bits 1 and 3 of the multiplier are 1. 

Now instead of upshifting the multiplicand, as illustrated above, we could downshift the product's space. This may be 
illustrated as follows: 



Step 1 : 



00000000 
10 1 



1010 



Step 2: 00000000 1010 

10 1 
0000 10 10 



Step 3: 



0000 10 10 10 10 
010 1 



Step 4: 



0000 10 10 10 10 

10 1 
00 1 10010 
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This is the algorithm we are about to use. This algorithm allows the multiplier to be stored in half of the product space, 
since this space is slowly shifted out. 

Returning to our 8-bit X 8-bit multiplication, after the first shift the 1 6-bit product space will be shared by the low-order 
nine bits of the product and the high-order seven bits of the multiplier: 



765432107 



5 4 3 2 1 



Carry 



1 1 1 II 1 II III 1'"'" 


-.\\\\\\\\\\\\\\\^" 


1 1 1 1 j 1 After first shift 



8 7 6 5 4 3 2 1 



7 6 



4 3 



' Product 



Multiplier 



and ultimately the sixteen bits of the product space will be occupied by the 1 6-bit product — after the entire multiplier 
has been shifted out. Each time the contents of the product space are shifted down one bit position, the next low-order 
bit of the multiplier will be shifted out and will appear at output pin RAMO. This output is tested. If it is 1, then the 
multiplicand is added to the high-order eight bits of the product space (the Q register) before the next shift occurs. The 
carry from the addition must become the next high-order product bit prior to the next addition. Therefore the carry is 
shifted into the high-order Q register bit via Q7. 

In this fashion, the multiplicand is added to the product in each bit position that corresponds to a 1 in the multiplier. 
The logic for this operation may be illustrated as follows: 

Since we have discussed multiplication algorithms in some detail in Volume 1, we will not spend more time in this 
chapter describing the theory of this multiplication algorithm. Rather, consider the following example: 

2C*A4=1C30 

Start 00000000001 01 1 00 

10 100100 
Step 1: 0000000000101100- 
Step 2: 0000000000010110- 
Step 3: 000000000000101 T- 



Step 4: 1010010000000101 



Step 5: 1111011000000010- 
Step 6: 0111101100000001- 



Step 7: 1110000110000000- 
Step 8: 0111000011000000- 
End 0001110000110000 



-00000000000 10 110 
-0000000000001 1 1 
-0000000000000 1 1 

10 100100 

10 1001 0000000 1 1 
-0 101001000000010 

10 100100 

11110 11 0000000 1 
■01111011 0000000 1 
-001111011 0000000 

10 100100 

1 1 1 0000 1 1 0000000 
111 0000 1 1 000000 
0011100001100000 



C = 



c = o 



c = o 



The algorithm above starts by downshifting Q and B registers' contents as a single 16-bit entity. Carry, which must in- 
itially be 0, is shifted into the high-order Q register bit via Q7, while the low-order bit of B appears at RAMO. If RAMO is 
0, then must be added to Q. If RAMO is 1 , then the multiplier in the local RAM location with address A must be added 
to Q. A second microinstruction accomplishes this addition. If this addition generates a carry, then the carry bit must be 
loaded into the next high-order product bit. By connecting the carry to Q7 we make sure that any carry is loaded into 
the next high-order product bit on the next downshift of Q and B registers' contents. Necessary logic is illustrated in 
Figure 22-15. 
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GND- 
+ 5V- 

GND- 
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+ 5V- 



1C0 
1C1 
1C2 
1C3 
2C0 
2C1 
2C2 
2C3 



1Y 



25LS253 



2Y 



QO 

Low- 
order 
2901 

RAMO RAMS 



C8 



Q7 



High- 
order 
2901 



RAM4 



RAM7 
FN 



17 SO SI 



CK 



1G A B 2G 



1Y 



25LS253 



2Y 



ICO 
1C1 
1C2 
1C3 
2C0 
2C1 
2C2 
2C3 



CY • CX 



+5V 



+5V 

< f 



<IK 



CP- 

CY • CX- 

II (IN)- 



CK 




II (OUT) 



Figure 8-15. 2901 Connections for Binary Multiplication 



In Figure 8-15, CX and CY high is the characteristic combination identifying binary naultiplication. As compared to 
Figure 8-12, we have modified the 1 CO and 2C0 inputs to the right-most 25LS253 device so that when CY and CX are 
both high, a downshift loads the Carry out into the high-order bit of Q7, while QO is loaded into RAM7 — and thence 
into the high-order bit of the local RAM location with address B. Thus a downshift treats the Q and local RAM locations 
as a single 16-bit register, which, following a downshift, causes a prior carry to be input at Q7 while the low-order 
multiplier bit is output at RAMO. 

Before describing the logic surrounding II in Figure 8-15, let us look at the two microinstructions which must be ex- 
ecuted sequentially within a loop in order to perform the required multiplication. First we execute a downshift 
microinstruction, then we execute an add microinstruction, as follows: 




11001100000011XXXX X X X X X X X XBBBBXXXX 
21 20 IF IE 1D1C 1B1A19 18 17 16 15 141312 11 10 OF OE 00 OC OB DA 09 08 07 06 05 04 03 02 0100 
CVCXSISOSElB 17 16 IS 14 13 12 II 10 T1 TO M1 MO OH3DH2 DH1 OHO DL3 DL2 DL1 DL0B3 82 B1 BO A3 A2 A1 AO 



Specify multiplication 

Disable Y output 

Downshift Q and B 

Move 8 contents through ALU 

Lower half of Product/multiplier 

Don't care 



- Microinstruction bit 




Local RAM A address 

Local RAM B address 

Low-order 2901 immediate data in 

High-order 2901 immediate data in 

Source select 

- Immediate data from microcode 

1 - Data from buffer 1 

1 - Data from buffer 2 
1 1 - Data from buffer 3 

Destination select (Four arbitrary destinations) 

Instruction code 

Output enable 

Shift/rotate logic control 

Carry in control 

- in 

1 - 1 in 



1 0- 



source 1 i 
source 2 i 




OOOOOOXOXXXX X X X X X X X XBBBBAAAA 
lie 181A1918 17 16151413 12 11 10 OF OE OD OC 0B0A09 08 07 06 05 04 03 02 0100 
'|8 17 16 IS 14 13 12 II 10 T1 T0M1 MO DH30H2 0H1 DH0DL3 0L2DL1 DL0B3B2B1 80A3A2A1 AO 






Multiplication specified 

Disable Y output 

Store sum in Q 

Add two operands 

and Q or A and Q form ALU operands 

Initial multiplier/final product low-order 

eight bits address in local RAM 
Local RAM multiplicand address 
Don't care 



-Microinstruction bit 



-Local RAM A address 
-Local RAM B address 
-Low-order 2901 immediate data in 
■^High-order 2901 immediate data in 
-Source select 
- Immediate data from microcode 

1 - Data from buffer 1 

1 - Data from buffer 2 
1 1 - Data from buffer 3 

-Destination select (Four arbitrary destinations) 
-Instruction code 
-Output enable 
-Shift/rotate logic control 
- Carry in control 
- in 

1 - 1 in 

1 - source 1 in 
1 1 - source 2 in 
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The downshift microinstruction is self-evident. Note, however, that RAMO nnust becorne the II instruction bit for the 
addition so that will be added to Q when RAMO outputs 0, while the contents of the local RAM location addressed by 
A are added to Q when RAMO outputs 1. But when CY and CX are not both high, binary multiplication is not in 
progress; therefore II comes directly from the microinstruction. The three NAND gates shown in Figure 8-15 provide 
the necessary logic. 

The multiplication example we have just described is a useful illustration of 2901 logic, but the 2903, which we de- 
scribe next, performs binary multiplication and division automatically. 
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THE 2903 MICROPROCESSOR SLICE 

The 2903 is a 4-bit microprocessor slice. The 2903 is conceptually similar to the 2901, which we have already 
described. The 2903 has more versatile signals than the 2901, and more on-chip functions: however, the 2903 
and the 2901 are driven by clocks with approximately equal frequency. But remember, the 2901 A and 2901 B 
are faster than the 2901 ; therefore, they are faster than a 2903 — excluding special 2903 functions. The 2903A 
is currently in development and, when available, will offer faster operation than the 2903. 

The 2903 is not a superset of the 2901. Microprograms written for the 2903 and the 2901 will be connpletely 
different; so will external logic supporting the two devices. Nor is the 2903 always the part of choice, as connpared to a 
2901. If your application uses a lot of complex arithmetic and logic operations, or if your application requires a large 
number of local registers, then the 2903 is the part of choice. But if your application stresses execution speed, then the 
2901 A or 2901 B may be a better choice. 

2901 and 2903 ALU logic also differ sharply. The 2903 performs operations which encompass the simple 2901 ALU 
functions; the 2903 also performs a separate set of more complex operations. Furthermore, 2903 ALU logic discrimi- 
nates between a high-order slice, a low-order slice, and an intermediate slice; 2901 logic makes no such 
high/intermediate/low-order distinctions. By discriminating between high-order, low-order, and intermediate slices, 
the 2903 is able to perform operations on non-symmetrical data. For example, a twos complement binary number is 
non-symmetrical since the high-order bit is a sign bit subject to different interpretation from other bits, which are mag- 
nitude bits. Also, by discriminating between high-order, low-order, and intermediate slices, the 2903 makes double use 
of many signals; signals perform secondary functions at slices where the primary function is meaningless. For example. 
Carry, Generate, and Propagate signals share pins with Overflow and Sign status, since the Carry, Generate, and Pro- 
pagate signals are meaningless at the most significant slice, while status signals are meaningful only at the most sig- 
nificant slice. 

In the description of the 2903 which follows, we will compare and contrast the 2903 with the 2901. We will 
refer to the 2901 description, together with Chapter 4 of Volume 1 for all conceptual information. 

The 2903 is packaged as a 48-pin DIP. It uses bipolar LSI technology. 

A 2903 FUNCTIONAL OVERVIEW AND COMPARATIVE ANALYSIS 

Figures 8-16 and 8-17 functionally illustrate 2903 logic. Figure 8-16 is a variation of Figure 8-1. given earlier in 
this chapter, and of Figure 4-3, from Volume 1; it illustrates the 2903 in terms of the general chip slice description 
given in Chapter 4 of Volume 1. Figure 8-17 is a more accurate representation of 2903 logic and data paths. 

Superficially the 2903 and the 2901 look very similar. Both have an arithmetic and logic unit which receives two in- 
puts and generates a single output. Both have a 1 6 x 4-bit, two output-port RAM, additional local data storage in the 4- 
bit Q register, and two sets of shift logic. 

The 2903 1 6 x 4-bit local RAM, like the 2901 , receives two 4-bit addresses — the A and B addresses. Data can be writ- 
ten into the 2903 local RAM location addressed by B, but only when the separate WE control input is low. The 2901 
has no signal equivalent to WBpata addressed by A and B is output to the 2903 A and B latches; but the 2903 B latch 
has an output enable control, OEg, which must be low for the B latch contents to be passed on. The 2901 has no signal 
equivalent to OEg. 

Both 2901 and 2903 A and B latch outputs are transmitted to the R and S ALU input multiplexers; but that is the only 
similarity between the two sets of ALU input logic. The 2901 uses three instruction code bits to generate eight possible 
combinations of R and S inputs. The 2903 uses one instruction code bit, together with two new control signals to select 
substantially different ALU operand combinations. The 2903 then makes up for the lack of operand input options with 
additional ALU functions. 

Both 2901 and 2903 ALU outputs may go to the Q register, the Y port, or the 16 X 4-bit local RAM. 

Like the 2901 , the 2903 Q register has shift logic at its input. The 2903 also has shift logic on the local RAM data path; 
but 2903 shift logic precedes the Y outputs, and has a separate output enable control signal OEy like the 2901. 

Perhaps the most obvious difference between the 2901 and the 2903 lies in the data input and output ports. 

The 2901 has a single data input port, D0-D3, and a single data output port, Y0-Y3. The 2903 has the same data input 
port, DA0-DA3, but the 2903 has two bidirectional data output ports, DB0-DB3 and Y0-Y3. 
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Figure 8-16, The 2903 Microprocessor Slice 
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Figure 8-17. 2903 4-Bit Slice Logic 




2903 




Pin Name 


Description 


Type 


DAO - DAS 


Data Input 


Input 


DBO - DB3 


Data input/output 


Input/output 


AO -A3 


Local RAM A address 


Input 


BO -B3 


Local RAM B address 


Input 


EA 


ALU R input select 


Input 


WE 


Local RAM write enable 


Input 


YO- Y3 


Data input/output 


Input/output 


OEb 


RAM B output/DBO - DB3 input enable 


Input 


GEy 


YO - Y3 output enable 


Input 


SIOq. SIO3 


RAM shifter controls 


Bidirectional 


QIOq, QIO3 


Q shifter controls 


Bidirectional, Tristate 


CN 


Carry logic input 


Input 


C(N+4) 


Carry logic output 


Output 


G/N 


Carry look ahead generate/Negative status 


Output 


P/OVR 


Carry look ahead propagate/Overflow status 


Output 


Z 


Zero status/control 


Bidirectional, Open collector 


10-18 


Instruction code 


Input 


lEN 


Instruction enable 


Input 


LSS 


Least significant slice select 


Input 


WRITE/MSS 


Most significant slice select/Write indicator 


Bidirectional 


Vcc. GND 


Power, Ground 





Figure 8-18. 2903 Microprocessor Slice Pins and Signal Assignnnents 
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2903 MICROPROCESSOR SLICE PINS AND SIGNALS 

Pins and signal assignments for the 2903 are illustrated in Figure 8-18. We will summarize functions per- 
formed by each of these signals superficially before examining device operations in detail. 

2903 signals can be divided into these three categories: 

1) Data inputs and outputs 

2) Instruction and control inputs that are generated by a microinstruction 

3) Control and status signals connecting 2903 slices, and status signals generated by 2903 slices 

First consider data inputs, outputs and associated address signals. 

A0-A3 and B0-B3 are two 4-bit addresses which select locations within the 290 3 loc al 16 x 4-bit RAM. Data 
may be written Into the local RAM location addressed by B — but only while both WE and the clock signal, CP, 
are input low. 

While CP is high, the contents of the local RAM location addressed by A0-A3 are written into the A latch — which is 
therefore changing continuously. When CP goes low, the A latch contents are stable, holding whatever data was read 
from local RAM at the instant that CP made its high-to-low transition. The A latch contents are continuously output to 
the ALU R input multiplexer. 

The B latch output is enabled by the OEp control signal. When this signal is high, the B latch still receives data from the 
local RAM location addressed by B0-B3, but the B latch output is floated. 

If OEg is low and the B output from local RAM is enabled, then DB0-DB3 becomes a 4-bit output. The B output ap- 
pears at DB0-DB3, as illustrated earlier. When OEg is high and the B latch output is disabled, DB0-DB3 becomes a 4- 
bit data input. Data input via DB0-DB3 can be selected as the ALU S operand. 

DA0-DA3 always functions as a 4-blt data input. 

The R input tqthe ALU may be the A latch output from local RAM, or the DA0-DA3 external 
data input. If EA is high, then DA0-DA3 is selected. If EA is low then the local RAM A latch 
output is selected. 

The low-order instruction code input (10) determines the ALU S input. If 10 is high, the Q 

register output becomes the S input to the ALU. If 10 is low, the B output from the local RAM, or data input via DB0-DB3 

becomes the ALU S input. These options are summarized in Table 8-5; logically they may be illustrated as follows: 



2903 ALU 

INPUT 

OPTIONS 



A latch output- 



EA- 



DAO - DAS- 



=D-' 



-ALU R input 



B latch output- 

OEb- 

DBO - DB3- 
10- 



Q Register output- 






->o— ' 



O-i 



■ALU S input 



ALU input options are described in more detail later when we look at 2903 logic. 

Y0-Y3, which were data output pins of the 2901. are bidirectional 2903 pins (see Figure 8-17). 

OEy is a control signal which enables or disables the ALU output. If OEw is low, then ALU output, after passing 
through the ALU shifter, appears at the Y0-Y3 pins. But if OEy is high, ALU output is disabled and Y0-Y3 become input 
pins. Data input at Y0-Y3 can be written into the local RAM location addressed by B0-B3, provided WE and CP are low. 
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The 2903 has a 9-bit instruction code which is input via 10-18. The interpretation of this instruction code differs sharply 
fronn the 2901. Without reference to the 2901, the 2903 instruction code interpretation may be illustrated as 
follows: 

1 6 special functions 
See Table 22-8 

0. Select special functions 



■ Instruction code with bit number 



Select ALU S input 

See Table 22-5 
Not 0. Select ALU simple functions 

See Table 22-6 
Specify ALU output destination 

See Table 22-7 



F 


7 


6 


5 


4 


3 


2 


I 


3 




As illustrated above, the 2903 instruction code has two different interpretations. 

We can connpare 2901 and 2903 instruction codes, but to do so we must include the EA and OEo control inputs as in- 
struction code contributors. The two instruction codes may now be compared as follows: 

2901. 



2903: 




18 17 16 15 14 13 12 II EA 10 OEb 



Note that OEn and EA do not usually come from the microcode. 

2903 instruction code interpretations are quite complex and make use of additional control and status signals 
Therefore we will complete our summary of signals before examining instruction code interpretations in detail. 

Let us now examine status and control signals of the 2903. We have already described WE, EA, OEg, and OEy. 

The 2903 has logic to discriminate between a most significant slice, a least significant slice, 
or an intermediate slice. 



2903 SLICE 

SIGNIFICANCE 

SELECT 



Wh en LSS is inp ut low, a 2903 a cts as a least significant slice. As a l east significant slice, 

the WRITE/MSS signal becomes a WRITE output. As such. WRITE/MSS is output low for every 

micro cycle du ring which data is written into local RAM. Frequently the WE inputs for all 2903 slices will be connected 

to the WRITE output of the least significant 2903 slice. This may be illustrated as follows: 




Intermediate 



Intermediate 



Least 
Signficant 



+ 5V 



+5V 




+5V 



+5V 



2903 



LSS 



+5V 



2903 



W/MSS_ LSS 
WE 
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At interme diate and most significant slices, LSS is input high. Now t he W RITE/MSS signal becomes an MSS in- 
put. A low MSS input selects the most significant slice, while a high MSS input selects an intermediate slice, as 
illustrated above. 

lEN is described in vendor literature as an "instruction enable" input. This may lead you to believe that it enables 

or disables the 10-18 instruction code inputs, but in fact the effect of lEN is more limited. When low, I EN allows data 
to be written into the Q register, it also enab les the WRITE output at the least significant slice. When lEN is high, data 
can not be written into the Q register, and the WRITE output at the least significant slice is constantly output high. If the 
WE inputs for all slices are connected to the WRITE output of the least significant slice, then lEN high effectively dis- 
connects the instruction code input, since it prevents data from being written into the Q register or local RAM; but it 
does not prevent an instruction from being decoded and executed by the ALU, and it does allow data to be output via 
the DB and/or Y pins. 



2903 ALU logic has the standard Cajry In (CN) and Carry Out (C(N+4)) signals. The 2903 also has 2903 

the Carry Look-Ahead signals G and P. But if you look at the discussion of Carry Look-Ahead logic STATUS 

given in Chapter 4 of Volume 1 (and later in this chapter for the 2902), you will see that G and P SIGNALS 

outputs are not used at the most significant slice. Conversely, the Sign and Overflow status out- ^ 

puts are meaningful only at the most significant slice. Therefore 2903 pins share G with the Sign status (N) and P 
with the Overflow status (OVR)._These pins output_Sign (N) and Overflow (OVR) statuses at the most significant 
slice; they output Carry generate (G) and propagate (P) for intermediate and least significant slices. 

The 2903 also has an open-collector Zero status output (Z). This signal is output high when all ALU outputs are low. 

The 2903 makes additional use of its shifter signals (SIOO, SI03, QlOO, QI03) and its status signals (CN, 

C(N-f-4), N, OVR, and Z). These signals are occasionally used in special ways by ALU operations that do not use the 

signals for their primary purpose. For a summary see Table 8-8 and associated text. 

SIOO and SI03 are ALU shifter connections. QlOO and QI03, likewise, are Q register shifter connections. These 
signals allow shifts to occur across multiple slices as described for the 2901. These signals will always be connected as 
follows: 



Most 

Significant 

Slice 



Intermediate Slices 



Least 

Significant 

Slice 



Sign status* 
Overflow status « 




QlOO 
SIOO 



QI03 QlOO 

SI03 SIOO 

W/MSS 

LSS 



CP is the master clock signal used to control and synchronize events within the 2903. 
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2903 LOGIC 

We will now examine 2903 logic in detail. 

The best place to start understanding 2903 logic is at the read/write memory (local RAM) : 



ill! 



!A0 
A2 
A3 




The 2903 local RAM consists of sixteen 4-bit locations. You will use pins A0-A3 to identify the location from which 
data will be output at the A latch. You use pins B0-B3 to identify the 4-bit location from which data may be output to 
the B latch or into which data may be written via Y0-Y3. 



Data may be written into the local RAM location addressed by B 

may be illustrated as follows: 



B0-B3 



but only while WE and CP are input low. This 




WE 



Local RAM Data Stable I Data Changing I Data Stable 



RAM Location X 
X and Y are any two hexadecimal memory addresses 



Data Stable 



RAM Location Y 
High WE inhibits write 



As illustrated above, the contents of the local RAM location addressed by B are changing while WE and CP are both 
low. When CP goes high, contents of the addressed RAM location are stable, holding whatever data was input when 
CP made its low-to-high transition. If WE is high, local RAM is not accessed and its contents remain stable. 

Data is output from the local RAM locations addressed by A and B when CP is high. The contents of the local RAM loca- 
tion addressed by A are output to the A latch. The contents of the local RAM location addressed by B are output to the 
B latch. These outputs occur when CP is high; therefore the A and B latch contents are continuously changing while 
CP is high, but they are stable while CP is low, holding whatever data was input when CP made its high-to-low transi- 
tion. 
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The A latch contents are output continuously. We can therefore illustrate A latch output timing as follows: 



CP 



r 



I 



I 



X 



AO -A3 



1 



I 



XRead Q | Q Stable I Read R I R Stable IT 
* " * " 



A Latch 



Read P 



P Stable 



Local RAM 



I 



RAM Location P 



I 



X 



RAM Location Q 



X 



X 



RAM Location R 



P,Q, and R are any three hexadecimal addresses. S represents stable data, and C represents changing data in the 
selected RAM location. 

In the illustration above, the RAM location addressed by A is shown as stable while CP is high and changing while CP is 
low. The stable data is output to the A latch while CP is high. The A latch contents subsequently become stable while 
CP is low — at which time local RAM contents are changing until RAM access time has elapsed. Thus race conditions 
are avoided. 

The A latch outputs are continuously enabled. 

B latch timing is a Ijttle more complex than A latch timing because the^B latch has its own output enable control 
signal OEn- When OEg is high, the B latch output is floated. But when OEn is low, the B latch outputs are enabled. B 
latch timing may be illustrated as follows: 



CP 



BO -B3 



I 



X 



X 



I 



Read L ][ L Stable ^ Read M j[ M Stable \ Read N | N Stable ][ 



OEb 



B Latch output 



[M] 



DBO - DBS 



Input 



[M] 



Input 



[M] means "contents of RAM location M". 



Output 



The Y0-Y3 input to local RAM may come from the ALU output, or from the Y0-Y3 pins. 2903 ALU 

Unlike the 2901, there is no shifter at the local RAM input; rather, the shifter has been moved to INPUT 

the ALU output, and the shifter output is itself enabled or disabled by the OEw control input. If 
OEw is low, then the shifter output is enabled; it appears as output at Y0-Y3 and at RAM D0-D3. 
But if OEy is high, Y0-Y3 become input pins providing local RAM with its data input. 

The 2903 local RAM, like the 2901, generates a 4-bit slice through selected programmable registers of a 
Central Processing Unit. But it is much easier to extend 2903 local RAM using external memory. This is because 
the 2903 has one data input port and two bidirectional data ports situated between local RAM and the ALU. The 29705 
is used as an expansion RAM. 
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2903 ARITHMETIC 
AND LOGIC UNIT 



CPU register implementation and ALU operand inputs are logically dependent on each other, since the primary func- 
tion of CPU registers is to store ALU source or destination data. We will therefore explore the ALU operand options 
available using a 2903, and see what impact these options have on register implementation. 

Turning to the 2903 Arithmetic and Logic Unit, these three aspects of ALU logic are im- 
portant: 

1) The operands which are input to the ALU 

2) The ALU operation which is to be performed 

3) The destination for the ALU output. (The destination specification includes any shift operations.) 

Instruction code bit 10, together with EA and OEg, controls the data input to the 2903 ALU; instruction code bits II 
through 14 specify simple ALU functions, while 15 through 18 specify the destination and shift operation for simple func- 
tions. Instruction code bits 15 through 18 may also specify special 2903 functions. 

Table 8-5 shows the ALU operand source options that can be specified using 10, EA, and 
OEb- Let us now explore these options in detail. 

Table 8-5. 2903 ALU R and S Operand Selections 



2903 ALU 
OPERAND 
OPTIONS 



Control Signal 


R Operand 


S Operand 


EA 


10 


OEb 






1 
1 
1 





1 




1 




1 

0/1 


1 

0/1 


A latch output 
A latch output 
A latch output 
DAO - DAS input 
DAO - DAS input 
DAO - DAS input 


B latch output 
DBO - DBS input 
Q register output 
B latch output 
DBO - DBS input 
Q register output 
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Beginning with the logically simplest case, we will assume that EA is low, so the A latch output becomes the ALU R in- 
put. Any of the ALU S input options could also accompany EA high, in which case DA0-DA3 becomes the ALU R input. 
Consider Q0-Q3 providing the ALU S input, while DB0-DB3 is idle: 



DO -D3 



il 



Local RAM 



I 



A Latch 



DAO - DA3 C 



EA = 



1 



B Latch 



S 



■ OEb = 1 



i£ 



RMUX 



E 



V 



i£ 



3dB0 - DB3 



IqO - Q3 



SMUX 



I 



10= 1 



ALU 



Data paths illustrated above would probably be used by a complex ALU operation involving one source operand. This 
source operand comes from local RAM via the A latch, while the complex ALU operation acts on temporary data held in 
the Q register. 
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Now consider the same data paths illustrated above, but with OEg input low, so that B latch data is output via DBO- 
DB3: 



DO- D3 



H 



Local RAM 



II 



A Latch 



DAO - DA3 4_ 



EA = 



i 



RMUX 



1 



I 



B Latch 



5 



\z 



il 



— OEb = 1 
"^ DBO - DB3 
& QO - Q3 



SMUX 



10 = 1 



i^ 



ALU 



Data being output via DB0-DB3 will probably conne from a CPU register implemented in local RAM. DB0-DB3 could be 
connected to external read/write memory within which additional CPU registers are implemented. The direct data path 
from local RAM to DB0-DB3 can be used effectively to implement any register-to-register operation within a CPU. If, for 
example, an Accumulator or other primary register is implemented in local RAM while secondary registers are held in 
external RAM, then the data path illustrated above lends itself readily to register-register data transfers, which may, or 
may not, occur in parallel with any other CPU operation. 
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Now consider the data paths we just illustrated, but with EA high, so that the ALU R operand comes from the external 
data inputs DA0-DA3, This may be illustrated as follows: 

DO - D3 



iZ 



Local RAM 



H 



A Latch 



DAO - DA3 t 



EA = 1 



i 



s 



B Latch 



^ 



OEb = 



ii 



^ 



DBO - DB3 



RMUX 



IZ 



i£ 



J QO - Q3 



S MUX 



\z 



10= 1 



LZ 



ALU 



Data input via DA0-DA3 may be immediate data coming from a microinstruction, or non-immediate data taken from 
any other source. DA0-DA3 may also receive its input from an external RAM within which additional CPU registers are 
held. 
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But, moving away from complex operations that may require the ALU S operand to come from the Q register, let us ex- 
amine some more complex data paths used by simple CPU operations. In the simplest case, the two ALU operands will 
come from local RAM. This may be illustrated as follows: 

DO -D3 



H 



Local RAM 



II 



A Latch 



DAO - DAS C 



EA = 



i 



i^ 



R MUX 



I 



s 



B Latch 



^ 



OEb = 



\z 



fr 



3 DBO - DB3 
3 QO - Q3 



S MUX 



I 



10 = 



ALU 



Data paths illustrated above show two ALU operands being taken from local RAM locations — probably CPU registers. 
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We can take the S ALU input from DB0-DB3 by inputting OEg high, thus enabling the data from the B latch. This may 
be illustrated as follows: 



DO -D3 
Pi 



i^ 



Local RAM 



I 



A Latch 



B Latch 



DAO - DA3 C 



ll 



\7 



H 



ii 



n 



-OEb = 1 
3 DBO - DB3 
3 QO - Q3 



EA = 



RMUX 



IT 



SNiux 



II 



10= 



ALU 
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Data entering at DB0-DB3 could be immediate data coming from a microinstruction, or data from an external RAM 
location being used to implement additional CPU registers. By inputting EA high, we can take both the R and S ALU in- 
puts fronn external RAM: 



DO -D3 



ii 



Local RAM 



S 



A Latch 



DAO - DAS C 



EA= 1 



H 



s 



B Latch 



? 



0Eb = 1 



IZ 



RMUX 



>Z 



i£ 



y DBO - DB3 
15 QO - Q3 



SMUX 



\> 



10= 



ii 



ALU 



In the illustration above you see one of the more significant 2903 advantages, as compared to the 2901. The 2901 
allows a single operand to be taken from external RAM, and that reduces the effectiveness of external RAM as a means 
of implementing the two-port CPU registers in a 2901 configuration. It limits you to CPU architectures that include a 
group of secondary registers, only one of which can provide an ALU operand during the execution of any instruction. 
But the 2903, by allowing external data inputs to the R and S ALU operands, allows you to implement CPU registers in 
internal local RAM, or in external RAM like the 29705, without compromising register logic associated with either im- 
plementation. 
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The 2903 has local RAM addressing. The 2901 allows you to specify just two local RAM ad- 
dresses within a single microcycle. The A and B addresses identify the two ALU operands while 
the B address also identifies the destination address for the ALU product. Thus the ALU operand 
specified by the B address must be overwritten if the ALU product is to be returned to local RAM. 
But the 2903 allows either two or three local RAM addresses to be specified within a single 
microcycle; you have the option of creating one, or two B addresses within a single microcycle. If 
you create one B address, timing may be illustrated as follows: 



2903 

LOCAL RAM 
ADDRESSING 



2903 TWO- 
ADDRESS 
TIMING 



CP 



WRITE =WE 



\. 



I 



AO- A4 



Operand R Address 



BO -B4 



Operand S and Result Address 



A and B provide the two local RAM addresses. As described earlier, while CP is high the contents of these two local 
RAM locations are output to t he A and B latches. Subsequently, when CP is low , data is written back to the local RAM 
loc ation ad dressed by B , since WE is low. In the illustrati on abov e, we show WE being driven low at the proper time by 
the WRITE output. WE will usually be connected to the WRITE output from the least significant 2903 slice. 

We generate three local RAM addresses in a single 2903 microcycle by changing the B ad- 2903 THREE- 
dress after reading an operand, and before writing back the result. Timing may be illustrated ADDRESS 
as follows: MICROCYCLE 




AO - A4 



m 



BO -B4 



Operand S 
Address 



Result Address! 



In the illustration above we delay lEN going low until the last quarter of the microcycle. This gives external logic suffi- 
cient ti me to change the B address. While lEN is high, WRITE is held high. Thus, delaying the lEN low pulse delays the 
WRITE pulse — which in turn delays the WE low in^m until a new address is stable at B. You can generate three-ad- 
dress timing, as illustrated above, by changing the lEN waveform from its normal two-address shape; 



CP 



lEN 
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to the following continuous three-address shape: 

\ ( 



CP 



lEN 



L [ 



KH 



I 1 

I I 



You cannot directly drive WE from external logic in order to create a three-address micro cycle since external logic may 
not be able to identify mi croc ycl es duri ng which no write operation is t o occur — and WE should be held h igh. By 
using lEN, and connecting WE to WRITE, you use lEN logic to provide WE with its correct shape, while you use WRITE 
to discriminate between microcycles within which a write should, or should not, occur. 

You use instruction code bits 10 through 14 to distinguish between simple ALU functions and 
special 2903 functions. When the five instruction code inputs 10-14 are all low, 15 through 18 are 
interpreted by the 2903 as "special function" identifiers. If one or more of the five inputs 10-14 
are high, then simple ALU functions are interpreted as summarized in Table 8-6. These sim- 
ple functions are all self-evident and need no special discussion. 



2903 
SIMPLE 
ALU 
FUNCTIONS 





Table 8-6. 2903 Simple ALU Function Specifications 






Instruction 
Code 


ALU Operation and 


ALU Dependent Output Signals 




P/OVR 


g7n 






Output 


C(N+4) 








Z 


14 13 12 11 10 




MSS 


Other 


MSS 


Other 





See Table 22-8 














1 


All ALU outputs high 











N 


G 





1 X 


S - R - 1 + CN 


C(N+4) 


OVR 


P 


N 


G 


z 


1 X 


R - S - 1 + CN 


C(N+4) 


OVR 


P 


N 


G 


z 


1 1 X 


R + S + CN 


C(N+4) 


OVR 


P 


N 


G 


z 


1 X 


S + CN 


C(N+4) 


OVR 


P 


N 


G 


z 


1 1 X 


S + CN 


C(N+4) 


OVR 


P 


N 


G 


z 


1 1 X 


R + CN 


C(N+4) 


OVR 


P 


N 


G 


z 


1 1 1 X 


R + CN 


C(N+4) 


OVR 


P 


N 


G 


z 


1 X 


All ALU outputs low 











N 


G 


1 


1 1 X 


RANDS 











N 


5 


z 


1 1 X 


R EXCLUSIVE NOR S 











N 


G 


z 


1 1 1 X 


R EXCLUSIVE OR S 











N 


G 


z 


1 1 X 


RANDS 











N 


G 


z 


1 1 1 X 


RNORS 











N 


G 


z 


1 1 1 X 


R NAND S 











N 


G 


z 


1 1 1 1 X 


RORS 











N 


G 


z 


R = R operand Input 










S = S operand input 










R and S are the complements of R and S operand ir 


iputs, respectively 








CN = Carry in. C(N+4) = Carry out 










MSS = Most Significant Slice 











Table 8-6 also summarizes output signal levels associated with each ALU operation. Additional signal levels more 
closely associated with the ALU destination specification are given in Table 8-7. 
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Table 8-7. 2903 Destination and Shift Specifications for Simple ALU Operations 



Instruction 


Shifter/Destination Summary 


Signal Detail | 


Code Bits 


ALU Output 


Q Register 


Y3 

MSS^) 


Y3 
Other 


Y2 
MSS^ 


Y2 
Other 


YO 

All 


SI03 

MSS^' 


SI03 
Other 


SIOO 
All 


ai03 


OIOS 


QlOO 




18 17 16 15 


Hex 
Code 


Shift 


Result 
(=Yif 

oiY = o) 


Shift 


Load 


WRITE 








Da2) 


(F/2)a 


None 


Q 


F3 


SI03 


SI03 


F3 


F2 


F1 






FO 


Hi-Z 


Hi-Z 





1 


1 


DL3) 


(F/2)l 


None 


Q 


SI03 


SI03 


F3 


F3 


F2 


F1 






FO 


Hi-Z 


Hi-Z 





10 


2 


DA2) 


(F/2)a 


DL3) 


(Q/2)l 


F3 


SI03 


SI03 


F3 


F2 


F1 






FO 


1 


QO 





11 


3 


Dl3) 


(F/2)l 


DL3) 


(Q/2)l 


3103 


SI03 


F3 


F3 


F2 


F1 






FO 


1 


QO 





10 


4 


None 


F 


None 


Q 


F3 


F3 


F2 


F2 


F1 


FO 






P 


Hi-Z 


Hi-Z 





10 1 


5 


None 


F 


DL3) 


{Q/2)l 


F3 


F3 


F2 


F2 


F1 


FO 






P 


1 


00 


1 


110 


6 


None 


F 


None 


F 


F3 


F3 


F2 


F2 


F1 


FO 






P 


Hi-Z 


Hi-Z 


1 


111 


7 


None 


F 


None 


F 


F3 


F3 


F2 


F2 


F1 


FO 






P 


Hi-Z 


Hi-Z 





10 


8 


UA4) 


(2F)A 


None 


Q 


F3 


F2 


F1 


F1 


FO 


SIOO 


F2 


F3 


1 


Hi-Z 


Hi-Z 





10 1 


9 


UL5) 


(2F)l 


None 


Q 


F2 


F2 


F1 


F1 


FO 


SIOO 


F3 


F3 


1 


Hi-Z 


Hi-Z 





10 10 


A 


UA4) 


(2F)A 


UL5) 


{2Q)l 


F3 


F2 


F1 


F1 


FO 


SIOO 


F2 


F3 


1 


03 


1 





10 11 


B 


UL5) 


(2F)L 


UL5) 


(2Q)l 


F2 


F2 


F1 


F1 


FO 


SIOO 


F3 


F3 


1 


03 


1 





110 


C 


None 


F 


None 


Q 


F3 


F3 


F2 


F2 


F1 


FO 


F3 


F3 


Hi-Z 


Hi-Z 


Hi-Z 


1 


110 1 


D 


None 


F 


Ul5) 


(2Q)l 


F3 


F3 


F2 


F2 


F1 


FO 


F3 


F3 


Hi-Z 


03 


1 


1 


1110 


E 


None 


SIOO 


None 


Q 


SIOO 


SIOO 


SIOO 


SIOO 


SIOO 


SIOO 


SIOO 


SIOO 


1 


Hi-Z 


Hi-Z 





1111 


F 


None 


F 


None 


Q 


F3 


F3 


F2 


F2 


F1 


FO 


F3 


F3 


Hi-Z 


Hi-Z 


Hi-Z 





1 ) MSS = Most Signif ican 

2) DA = Down Arithmetic 

3) DL = Down Logical 

4) UA = Up Arithmetic 

5) UL = Up Logical 


t Slice 1 = 
P 

HI 

F3 


= Input pin 
= Parity of SI03, F 
-Z = High impedan 
, F2, F1 and FO are 


3, F2, F1, FO 
:e 
the four ALU output bits. F3 is the high-order bit. FO is the low-order bit. 











With regard to Table 8-6, note that the Carry Out signal, C(N-l-4), is active for arithnnetic operations only. 

P/OVR generates an_Overflow status (OVR) at the nnost significant slice, and a Carj7 propagate signal (P) at other slices. 
Like the Carry Out, P/OVR is active only for arithnnetic operations. Unlike P/OVR, G/N is active for all ALU operations — 
arithnnetic and logical. The nnost significant slice outputs the Sign status (N) which is, in fact, the level of the high- 
order ALU output bit. Other slices output the Carry generate signal (G). 

For a discussion of the Carry generate and propagate signals (G and P) refer to the 2902 description. 

The Zero status is active for all slices, during all simple ALU operations. The Zero status is output high when all four 
ALU output signals are low. The Zero status output is low otherwise. 

Let us now examine 2903 destination options. 



2903 

DESTINATION 

OPTIONS 



Table 8-7 summarizes destination and shift specifications implied by instruction code bits 

15 through 18 for the simple ALU operations sunnnnarized in Table 8-6. In Table 8-7 we show 

the ALU output and Q register operations, together with a detailed summary of associated 

signal levels. The detailed signal sumnnary is given since slice significance and shift specifications connbined make 

signal levels less than self-evident, if you look at the signal outputs shown in the signal detail section of Table 8-7, and 

compare these signal outputs with the illustrations of arithmetic and logic shifts given below, then the table will be 

easy to understand. 

Note that signals SIOO, QlOO, and QI03 are frequently in a high impedance state. 

Selected destination specifications hold WRIT E high. These specifications give you the option of not wr iting ALU out- 
put into local RAM — assuming that the WE inputs are connected to the least significant slice WRITE output. 

Destination code E propagates the SIOO input across all Y outputs. This code is used to extend the sign of a binary 
number, as we will describe later. 

Destination codes 4, 5, 6, and 7 report parity of the ALU output at the SIOO pin. Parity is reported for the 5-bit bin- 
ary number given by SI03, F3, F2, F1 , and FO. Odd parity generates a high output at SIOO while even parity generates a 
low output at SIOO. 

Parity logic of the 2903 is cascadable across chip slices since the SIOO parity output of each slice becomes the SI03 
input for the adjacent, less significant slice. The SIOO output from the least significant slice will always report the 

parity for the combined ALU output. We will demonstrate this multislice parity logic for the simple case of 8-bit data 
generated using two 2903 slices. This may be illustrated as follows: 



Most Significant 
Slice 



Least Significant 
Slice 



SI03 F3 F2 F1 FO SI00/SI03 F3 F2 F1 FO SIOO 
1001^0 0110 ^0 




Most Significant 
Slice 



Least Significant 
Slice 



SI03 F3 F2 F1 FO SI00/SI03 F3 F2 F1 FO SIOO 
1110 _1 0110 1 
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The ALU shifter, but not the Q shifter, gives you the option of specifying either an 
arithmetic or a logical shift. The Q shifter allows you to specify logical shifts only. 

Logical shifts treat all bits in the same way. Thus, an 8-bit upshift may be illustrated as follows: 

7 6 5 4 3 2 10 -^ Bit No. 

Before upshift 




7777777. 



C 



After upshift 



2903 

SHIFT 

LOGIC 



An 8-bit downshift may be illustrated as follows: 

7 6 5 4 3 2 10 -^ Bit No. 

Before downshift 



i 



^Av^w; 



After downshift 



An arithmetic shift assumes that the high-order bit is a sign bit — which must be excluded from any shift. Thus an 8- 
bit arithmetic upshift may be illustrated as follows: 

7 6 5 4 3 2 1 -^ Bit No. 

Before upshift 



7 



777777. 



C 



After upshift 



An 8-bit arithmetic downshift may be illustrated as follows: 

7 6 5 4 3 2 1 -^ Bit No. 

Before downshift 



^M 



After downshift 



The 2903 can perform arithmetic shifts since you must identify the most significant, least significant, and intermediate 
2903 slices in a multislice configuration. Thus, when you specify an arithmetic shift, logic internal to the most signifi- 
cant slice isolates the high-order bit from the shift, while intermediate and least significant slices perform simple logic 
shifts. 
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The 2903 ALU shifter is located on the ALU output, in front of the Y data input/output port. 

In contrast the 2901 ALU shifter is locatedjit the local RAM input. Also, the 2903 ALU shifter out- 
put can be enabled or disabled via the OEy control signal. Thus you have a large number of 
microprogram-selectable options for handling ALU output, over and above the destination op- 
tions summarized in Table 8-7. ALU output may be transmitted to local RAM: 



2903 ALU 
SHIFTER 



YO- Y3 



C 



2903 ALU 

OUTPUT 

DESTINATIONS 



7^ 



a 



Local RAM 






A Latch 



DAO - DA3 £ 



a 



IL 



II 



•WE=0 



CP = 



B Latch 



OEb 



y- 



\2_ 



i£ 



"^ DBO - DBS 

"~^ QO - Q3 



OEy = 



Shifter 



RMUX 



II 



S MUX 



I 



ALU 



:> 



To Q Register 
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By holding WE high you can output data at the Y pins, but not write the output to local RAM: 



YO- Y3 



C 



7% 



OEy = 



a 



Local RAM 



E 



A Latch 



DAO - DA3 £ 



Shifter 



EA 



a 



I 



B Latch 



P 



\z 



RMUX 



E 



<Z 



I 



SMUX 



<z 



ALU 






WE = 1 



CP= X 



OEb 



"^ DBO - DB3 



[^ To Q Regis 



In either of the above cases the data may be shifted up or down, if so specified by instruction code bits 15-18 (see Table 
8-7). 
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You can also discard the ALU output and use the Y pins as the data input port to local RAM: 
YO - Y3 Si 



OEy - 1 



If WE and OEy are both high, ALU output to Y0-Y3 or local RAM is discarded. 

You can use the last two ALU destination codes shown in Table 8-7 to extend a sign bit 
across one or more parallel 2903 devices within a single microcycle. Since the ALU destina- 
tion code is used to generate sign extend logic, this operation can occur in conjunction with 
any compatible ALU operation specified by instruction code bits 14, 13, 12, and II. 



WE = 




Q Register 



2903 SIGN 

EXTEND 

LOGIC 



ALU destination code F transmits the ALU output to the Y pins, and pulses WRITE low. Assuming that OEy and WE 
are both. low, the ALU output will appear at the Y pins, and will be written into local RAM while CP is low. 



ALU destination code E transmits the SIOO input across all four ALU output lines. Again, WRITE is pulsed low: if OEy 
and WE are both input low, then the SIOO level is output at all Y pms, and is written into local RAM while CP is low. 
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You can use this pair of ALU destination codes to extend a sign bit by applying the level of the sign bit to the SIOO 
input of those 2903 slices that are to extend the sign. Consider a 1 6-bit Central Processing Unit where the sign for the 
low-order byte must be extended across the high-order byte. This may be illustrated conceptually as follows: 



Most 






Least 


Significant 


Intermediate 


Intermediate 


Significant 


Device 


Device 


Device 


Device 


3 


2 


1 






15 


14 


13 


12 


11 


10 


9 


8 


7 


6 


5 


4 


3 


2 


1 


- 


[I 


z 


Z 


Z 


z 


z 


z 


z 


X 


Y 


Y 


Y 


Y 


Y 


Y 


3 


15 


14 


13 


12 


11 


10 


9 


8 


7 


6 


5 


4 


3 


2 


1 


- 


ll 


X 


X 


X 


X 


X 


X 


X 


X 


Y 


Y 


Y 


Y 


Y 


Y 


J 



-Bit No. 



Y I Before sign extension 



■Bit No. 



Y I After sign extension 



X = sign bit 
Y = data bit 
Z = Irrelevant bit 

A Central Processing Unit implemented using 2903 slices will automatically generate a sign extended ALU result for 
any arithmetic operation. You use sign extend logic to create data, rather than modify results of any computation. 

Suppose, for example, an 8-bit data input is received from an I/O port; if a 16-bit CPU is to interpret this data byte as a 
signed binary number, then the high-order bit must be propagated through the high-order byte of a 16-bit word as il- 
lustrated above. 

This is easily done using the E and F ALU destination codes. This is illustrated in Figure 8-19. 

Let us examine Figure 8-19. The two low-order 2903 slices are generating real data. These two slices therefore receive 
an F ALU destination code via 18-15. This destination code causes the ALU output to appear at the Y pins, and the high- 
order ALU output bit to appear at SI03. The two high-order 2903 slices generate the high-order byte across which the 
sign must be extended. These two 2903 slices therefore receive an E destination code via 18-15. The E destination code 
causes the SIOO input to be propagated across the ALU outputs. 



8-64 



Sign Out 



QI03 . -oc QlOO 
MSS 

SI03 2903 siOO 
C(N+4) CN 

OVR W/MSS 
N 

CO 

T LSS 
into ^£ 



16 ' 18 = 

111- 
15(3) = 0- 
I5(2) = 0- 
I5(1) = 1- 
15(0)= 1- 



B 



+5V 



QI03 
SI03 
C(N+4) 



QlOO 

SIOO 

CN 



IS 
2903 

W/MSS 
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MSS means Most Significant Slice 
IS means Intermediate Slice 
LSS means Least Significant Slice 
Y = data bit 
X = sign bit 



Figure 8-19. 2903 Sign Extend Logic 

2903 SPECIAL FUNCTIONS 

Let us now examine special 2903 functions. These functions are summarized in Table 8-8. 

Special functions are implied by instruction codes bits 15 through 18 when instruction code bits 10 through 14 are all 0. 
Nine special functions are provided; seven special function codes are unused. You should be sure not to use any 
of the unspecified special function codes since the 2903 device's response to these unspecified function codes is not 
guaranteed. 

Table 8-8 summarizes signal outputs and exact ALU operations associated with each of the special functions. 
Wherever a signal's primary purpose is meaningful, the signal is so used by a special function. Where a signal's primary 
purpose is not meaningful, the special function may generate an output to meet its specific needs. 

Do not attempt to understand ALU operations or signal utilization merely by inspecting Table 8-8. Many of the ALU 
operations, although absolutely accurate representations of ALU logic, rely on specific external pin connections to 
generate the required net effect. Signals, likewise, are used in special ways that depend not only on the special func- 
tion, but also on the required pin connections which have been arbitrarily selected by the 2903 designers. 

ALU logic and signal utilization is described in detail function by function. 

We will begin by examining the simpler 2903 special functions, since many of these simple special functions act as ac- 
cessory commands to the more complex functions. 

There are two normalization functions: a single length and a double length normalization. The double length 
normalization function is also the first twos complement divide instruction. 
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Table 8-8. 2903 Special Functions Summary 



Instruction 
Coded) 


ALU Operation 


ALU Function 


Associated Signals 1 


8103 


SIOO 


QI03 


QlOO 




C(N+4, 


P/OVR 


G/N 


1 


WRITE 


18 17 16 15 


MSS 


Other 


MSS 


Other 


MSS 


Other 


MSS 


IS 


LSS 





Unsigned multiply 


F = S + CNif2 = L 

F = R + S + CNif2 = H 


Hi-Z 


1 


FO 


1 


QO 





C(N+41 


OVR 


P 


N 


G 


1 


1 


QO 


1 


Unused 
































10 


Twos complement multiply 


F = S + CNif2 = L 

F = R + S + CNif2 = H 


Hl-Z 


1 


FO 


1 


QO 





aN+4) 


OVR 


P 


N 


G 


■ 


1 


QO 


11 


Unused 
































10 


Increment 


F = S + 1 + CN 


1 


1 


P 


Hi-Z 


Hi-Z 





C(N+4) 


OVR 


P 


N 


G 


Z 


z 


z 


10 1 


Sign/Magnitude twos 
complement 


F = S + CNifZ = L 
F = S + CNifZ = H 


1 


1 


P 


Hi-2 


Hi-Z 





C(N+4 


OVR 


P 


(2) 


G 


S3 


1 


1 


110 


Twos complement multiply, 
last cycle 


F = S + CN if Z = L 

F = S-R-1 +CNif2 = H 


Hi-Z 


1 


FO 


■ 


QO 





C(N-^4) 


OVR 


P 


N 


G 


1 


1 


QO 


111 


Unused 
































10 


Single length normalize 


F = S + CN 


F3 


F3 


Hi-Z 


Q3 


1 





(3) 


Q2®Q1 


P 


Q3 


G 


(4) 


(4) 


(4) 


10 1 


Unused 
































10 10 


Double length normalize 


F = S +CN 


R3®F3 


F3 


1 


Q3 


1 





(5) 


F2®F1 


P 


N 


G 


(61 


(6) 


(6) 


10 11 


Unused 
































110 


Twos complement divide 


F = S + R + CNifZ = L 
F = S-R-1 +CNifZ = H 




F3 


1 


Q3 


1 





C(N+4i 


OVR 


P 


N 


G 


(7) 


1 


1 


R30F3 


110 1 


Unused 
































1110 


Twos complement divide, 
final 


F = S + R + CNifZ = L 
F = S-R-1 +CNif2 = H 


F3 


F3 


Hi-Z 


Q3 


1 





C(N+4l 


OVR 


P 


N 


G 


(7) 


1 


1 


1111 


Unused 
































QO, Q1, Q2 and Q3 are the four Q register output bits. \ 1) 10 - 14 must all be 0. Hi-Z = Signal floated 

FO, F1 , F2 and F3 are the four ALU output bits. 1 Bit 3 is the high-order bit. 2) N if 2 = 0. S3 © F3 if 2 = 1 . I = Input signal 

RO, R1, R2 and R3 are the four R operand bits. / Bit is the low-order bit. 3) Q 3 ® Q2 at MSB. CiN+4i at other slices. P = Parity of SI03, Y3, Y2, Y1. YO 

SO, SI. 82 and S3 are the four S operand bits. ) 4) Zero status for Q register output. MSS = Most Significant Slice 

5) F3® F2 at MSS. ClN+41 at other slices. IS = Intermediate Slice 

6) Zero status for combined. 8-bit Q register and ALU outputs. LSS = Least Significant Slice 

7) Sign compare output. Other = IS or LSS 



The normalization operation upshifts the contents of a data word until the two high- 
order bits have different values. Zeros are shifted into low-order bit positions. Here are 
some normalization illustrations for 16-bit words: 



Initial 
0000001 1 1 0001 1 1 
1110101101000101 
0110101101011010 
0000000000000000 

1111111111111111 



Normalized 

1011 000 1 1 1 00000 
1010 110 1 000 10100 
01101011010 11010 

Cannot be normalized 

1 000000000000000 



2903 

NORMALIZE 
SPECIAL 
FUNCTIONS 



Each normalize instruction is executed in one microcycle. During tiiis microcycle one upshift occurs if the two high- 
order bits of the most significant slice S ALU operand are both 0, or both 1. No operation occurs if the two high-order 
bits differ. In order to complete the normalization process for a multibit word that has many leading or 1 bits, you 
must re-execute the normalize instruction the required number of times to shift out leading similar bits. If, for example, 
there are five leading bits, followed by a 1 bit, you will have to execute a normalize instruction four times before the 
data is normalized. On the fifth execution of the normalize instruction the data will be left unaltered. 

Your logic must identify the point at which data has been normalized; the normalize instruction outputs appropriate 
status signals to identify normalization — as we will describe shortly, 

If binary data is being interpreted as a signed binary number, then a positive number, after normalization, will have a 
in the high-order bit and a 1 in the adjacent bit: 

01 XXX — 

After normalization a negative number will have a 1 in the high-order bit and a in the adjacent bit. 

10XXX — 

The single length normalization instruction generates a data word out of the Q registers of 
parallel 2903 slices. Thus, you would generate an 8-bit data word out of two parallel slices as 
follows: 



-Bit No. 



2903 

SINGLE 

LENGTH 

NORMALIZATION 



MSS 


LSS 


Q 


Q 


Register 


Register 



Four 2903 slices generate a 16-bit data word as follows: 



15 14 13 12 11 10 9 



Bit No. 



MSS 


IS 


IS 


LSS 


Q 


Q 


Q 


Q 


Register 


Register 


Register 


Register 



MSS means Most Significant Slice. IS means Intermediate Slice. LSS means Least Significant Slice 

The double length normalization instruction generates a data word out of the Q register and 
the local RAM location addressed by B. Two 2903 slices would generate a 16-bit word as 
follows: 



2903 

DOUBLE 

LENGTH 

NORMALIZATION 



15 14 13 12 11 10 9 




-Bit No. 



MSS 


LSS 


MSS 


LSS 


Local 


Local 


Q 


Q 


RAM 


RAM 


Register 


Register 
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There are some differences between the single and double length normalization instructions resulting from the 
fact that the double length normalization instruction must use local RAM, and the ALU, while the single length 
normalization instruction needs Q register logic only. We will therefore look at the single length normalization 
instruction first. 

The single length normalization instruction performs a number of upshifts until the most significant 2903 Q register 
has different values in its two high-order bits. Each upshift requires one microcycle, therefore the total execution time 
for the normalization instruction is variable. But the C(N+4) and OVR outputs are used to identify the last, and sec- 
ond to the last microcycles of the single length normalization instruction. On the second to the last cycle the OVR 
signal is output high; OVR therefore outputs the Exclusive-OR of Q2 and Q1 at the most significant slice. C(N-l-4), 
likewise, outputs the Exclusive-OR of 03 and 02 at the most significant 2903 slice. This may be illustrated as follows: 

Q Register of 
Most Significant Slice 



Q3 



Q2 



Q1 



QO 



C(N+4) = Q3®Q2 
OVR = Q2 © Q1 

Thus C(N-l-4) goes high on the last microcycle of the single length normalization instruction, while OVR goes high on 
the previous microcycle. 

You cannot normalize a data word that is initially all bits. Since zeros are shifted into the low-order bit position 
with each upshift, the normalization operation would never end. The single length normalization instruction therefore 
outputs a high signal on the status line and terminates in a single microcycle. For this to be possible the single length 
normalization instruction uses Z status logic to indicate register contents, rather than ALU output. That is to say, Z is 
output high when all Q register bits are 0, not when all ALU outputs are 0. 

You will now understand the special information output via C(N-l-4), OVR, and Z signals, as shown in Table 22-8 for the 
single length normalization instruction. 

During each microcycle of a single length normalization instruction the Q register contents are recycled through 
Q shifter logic. ALU logic, which would otherwise be unused, adds the contents of CN to the S operand input. 

This logic allows you to count the number of microcycles — and therefore upshifts — performed by the single length 
normalization instruction. Assuming that WE, OEy, OEg, and 10 are all low and CN is high, then the RAM location ad- 
dressed by B becomes a microcycle counter. This RAM location becomes the ALU S operand, and the destination for 
the ALU output. The ALU output is simply the S operand input incremented by 1, assuming that CN is indeed high. 

Single length normalization instruction pin connections are illustrated in Figure 8-20. 

You can, if you wish, maintain a microcycle counter in exter nal m emory by inputting the ALU S operand from DB0-DB3 
and outputting the ALU result at Y0-Y3. This requires that WE and OEg be input high. 

If you execute the single length normalization instruction with 10 high, then the register contents also become the 
ALU S input. Now on each microcycle the register contents, before they are upshifted, are output by the ALU to YO- 
Y3, and/or local RAM, optionally incremented by 1 if CN is input high. 

Let us now examine the double length normalization instruction. The RAM location ad- 
dressed by B provides the high-order half of the word being normalized. 0103 from the most 
significant 2903 slice must therefore be connected to SIOO at the least significant 2903 slice. 
Also, you cannot use ALU logic to count instruction microcycles since ALU logic con- 
tributes to the normalization operation. Therefore CN must be input low, and if you wish 
to count microcycles you must use external logic or an extra microcycle per cycle. 

The high-order half of the word being normalized can come from internal or external RAM. If it comes from internal 
RAM then the RAM location addressed by B must provide the S operand to the ALU, and must receive the ALU output. 

But you can also use external RAM to provide the high-order half of the word being normalize d; no w DB0-DB3 gener- 
ates the ALU S operand and the ALU output is transmitted to Y0-Y3. For this to occur OEg and WE must both be high. 

The C(N+4) and OVR statuses identify the last and second to the last microcycles of the double length nor- 
malization instruction's execution — just as they do for the single length normalization instruction. The double 
length normalization instruction also terminates in a single microcycle when you attempt to normalize a word which is 
initially 0. At this time the Z status is output high. For this to be possible double length normalization logic tests the 
combined contents of the register and ALU output in order to generate a Z status — as indicated in Table 8-8. Dou- 
ble length normalization pin connections are illustrated in Figure 8-21 . 



2903 

DOUBLE 

LENGTH 

NORMALIZATION 
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+5V 



Z = QO . Q1 



Q3- 

Q3 AAQ2- 
Q2 A/-Q1- 
Q3- 



QN 



QI03 
SI03 
C(N+4) 



QlOO 

SIOO 

CN 



OVR W/MSS 

N ^SS 
2903 

LSS 

WE 



+5V 



QI03 
SI03 
C(N+4) 



QlOO 

SIOO 

CN 



IS 
2903 
W/MSS 



LSS 



WE 



+5V 
O 



QI03 
SI03 
C(N+4) 



QlOO 

SIOO 

CN 



IS 
2903 
W/MSS 



LSS 



WE 



+ 5V 
O 



QI03 
SI03 
C(N+4) 



QlOO 

SIOO 

CN 



LSS 
2903 
W/MSS 



LSS 



WE 



I 



ALU output = [S] + CN. If WE, OEb. OEy and 10 are low, [B] = [Y] = [B] + CN | 


[Q] = [Q] upshifted one bit 




MSS means Most Significant Slice 


[S] = S ALU Input 


IS means Intermediate Slice 


[B] = Local RAM contents addressed by 8 


LSS means Least Significant Slice 


[Y] = Y output 




[Q] = Q register contents 



Figure 8-20. 2903 Single Length Normalization Function Pin Connections 

Another simple 2903 special function is the Sign/Magnitude Twos Complement. This func- 
tion converts negative twos complement numbers to this positive form, while leaving posi- 
tive twos complement numbers alone. This may be illustrated as follows for 16-bit numbers: 



Initial 
01100 10111010010 
1110101111010101 



After Sign/Magnitude 
Twos Complement 

0110010111010010 
000 10 10000101011 



2903 SIGN/ 

MAGNITUDE 

TWOS 

COMPLEMENT 

FUNCTION 



Unchanged positive number 

Twos complement of negative number 



The 2903 uses slightly devious logic in order to implement the Sign/Magnitude Twos Complement function. This is the 
actual ALU algorithm executed: 



ALU output 
ALU output 



[S] -F CN if Z status is 
[S] -F CN if Z status is 1 



[S] means ALU S operand. S is the complement of the S operand. 
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+5V 



Z = FO . F1 



FN • QO . Q1 . QN 



F3' 
F3A/-F2" 
F2-V-F1' 

F3- 



QI03 QlOO 

SI03 SIOO 

C(N+4) CN 

OVR W/MSS 

MSS 
N 



2903 



LSS 



WE 

— T" 



+5V 



QI03 
SI03 
C(N+4) 



QlOO 

SIOO 

CN 



IS 
2903 
W/MSS 



LSS 



WE 



+5V 
O 



0103 
SI03 
C(N+4) 



0100 

SIOO 

CN 



IS 
2903 
W/MSS 



LSS 



WE 



+5V 

o 



0103 
SI03 



QlOO 
SIOO 
CN 



C(N+4) 

LSS 
2903 
W/MSS 



LSS 



WE 



n. 



ALU output = [S] + CN. If WE. OEg, OEy, CN and 10 are low, [B] = [Y] = 2 [B] 
ALU output is upshlfted one bit 
[Q] = [Q] upshifted one bit 

MSS means Most Significant Slice 

IS means Intermediate Slice 

LSS means Least Significant Slice 

[S] = S ALU input [B] = Local RAM contents addressed by B 

[Y] = Y output 

[Q] = Q register contents 



Figure 8-21. 2903 Double Length Normalization Function Pin Connections 

During execution of the Sign/Magnitude Twos Complement instruction, the Zero status at the most significant 2903 
slice directly outputs the high-order S operand bit — which is the sign bit for a twos complement number. The Zero 
status becomes an input to intermediate and least significant slices, which therefore receive the sign bit from the most 
significant slice. For a 16-bit number this may be illustrated as follows: 



-Bit No. 



Most 




Least 


Significant 


Intermediate 


Significant 


Slice 


Slices 


Slice 



15 14 13 12 11 10 



Z = Y 



Z = Y 



Z = Y 



t 

Z = Y 



i I t 



Now you can connect pins of 2903 slices in any way to malce use of the Sign/Magnitude Twos Complement 
ALU logic, but to use it for its intended purpose, the connections illustrated in Figure 8-22 are required. 
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+5V 



S3- 



QI03 QlOO 

SI03 SIOO 

C(N+4) CN 



OVR W/MSS 

N "^^^ 
2903 

LSS 

WE 



+5V 



QI03 
SI03 
C{N+4) 



QlOO 

SIOO 

CN 



IS 
2903 
W/MSS 



LSS 



WE 



+5V 

o 



Qi03 
SI03 
C(N+4) 



QlOO 

SIOO 

CN 



IS 
2903 
W/MSS 



LSS 



WE 



+ 5V 
Q 



QI03 
SI03 



QlOO 
SIOO 
CN 



C(N+4) 

LSS 
2903 
W/MSS 



LSS 



WE 



ALU output = [SI + CN if Z = 0, or [S] + CN If Z = 1 . If WE, OEb, OEy, CN and 10 are low, 
[B] remains unaltered if Z = 0, or [B] = [B] + 1 if Z = 1 
In either case [Y] = ALU output 

Neither ALU nor Q shifter function 
*OVR = 1 if ALU input is 1000-00, the most negative binary number. 

"N = F3 if Z = 0, or F3 ® S3 if Z = 1 

MSS means Most Significant Slice 

IS means Intermediate Slice 

LSS means Least Significant Slice 

[S] = S ALU input. 

[S] = complement of S ALU input 

[F] = ALU output 

[B] = Local RAM contents addressed by B 

[Q] = Q register contents 

F3 = High-order ALU output bit from most significant slice 

S3 = High-order ALU S operand input bit to most significant slice 



Figure 8-22. 2903 Sign/Magnitude Twos Complennent Function Pin Connections 

By connecting Z to CN positive, twos complement numbers are passed unaltered through the ALU: 

[F] = [S] + CN if Z = 
CN = Z, therefore [S] = [S] + 

But a negative twos complement number is complemented and then incremented: 

[F] = [S] + CN if Z = 1 
CN = Z, therefore [S] = [S] + CN 

In other words, a twos complement number is twos complemented — which generates a positive number. (If you are 
unclear on this twos complement logic refer to Volume 1, Chapter 2.) 
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The negative status, N, is output high at the most significant slice if a negative twos complement number was 
converted to its positive form. This is the actual logic used by the most significant 2903 slice: 

If Z = 0. N = F3 

Z = when S3 = 0, in which case [F] = [S] 

Therefore N = F3 = S3 = 
If Z = 1, N = F3 eS3 

Z = 1 when S3 = 1, in which case [F] = [S] + 1 

Therefore N = F3 © S3 = S3 © S3 = 1 

The Overflow status indicates the only overflow condition which can occur when a Sign/Magnitude Twos Connple- 
ment conversion is perfornned. There is no twos complement positive representation for the most negative twos 
complement number which can be represented: 

If [S] = 1000 

[F]=0111 1+1. = 1000 

If this most negative number is received at the S operand, it is passed through unaltered and the Overflow status from 
the most significant slice is output high. 

The Sign/Magnitude Twos Complement instruction places no restrictions on where the S operand may come from. Any 
of the three options — external memory, local RAM, or the Q register — may provide the S operand to the ALU. 

The third and last of the simple 2903 special functions is the Increment. This special func- 
tion adds 1, plus the Carry In to the S operand. This algorithm may be illustrated as follows: 

[F] = [S] + 1 + CN 



2903 

INCREMENT 

FUNCTION 



2903 

UNSIGNED 

MULTIPLY 



[F] is the ALU output, [S] is the ALU S operand input, and CN is the Carry In. If CN is 0, you increment by 1 ; if CN is 1 
you increment by 2. This is useful in byte/word machines if the Program Counter is kept in local RAM. 

Once again the S operand may come from external or local RAM or from the Q register. 

The increment special function makes no special use of status logic. 

Let us now look at the unsigned multiply special function. The algorithm used by the 2903 
to perform an unsigned multiply is exactly the same as the algorithm which we described 
earlier in this chapter, when showing how to program an unsigned multiply for the 2901. In- 
itially the multiplier must be in the register and the multiplicand in the RAM location which provides the ALU R input. 
This may be external RAM connected to DA0-DA3, or local RAM addressed by A. The product will be generated in the 
RAM location that receives ALU output, and the register. The RAM location connected to ALU output may be exter- 
nal RAM connected to Y0-Y3, or local RAM addressed by B; it ultimately holds the upper half of the product. The Q 
register holds the lower half of the product. The RAM location that finally holds the upper half of the product must in- 
itially contain 0. Thus we can illustrate initial and final data locations as follows: 



Multiplicand Multiplier 



Initial 



Multiplicand 



Final: R 



U- 


1 


Product 
upper lower 


r^ 






The 2903 unsigned multiply operation will multiply two 16-bit numbers to generate a 32-bit product. If you 
wish to multiply larger numbers you must do so in 16-bit increments and add partial products using additional 
microcycles. 

If we compare the register utilization illustrated above with the unsigned multiply description given for the 
2901, the local RAM location addressed by B in the illustration above becomes the window into which the multipli- 
cand is added whenever a 1 bit is shifted out of the multiplier; but 2903 logic tests this bit internally, outputting the 
least significant Q register bit from the least significant 2903 slice via the Z status. The Z status becomes an input to 
the most significant and intermediate slices, so that these 2903 devices can also tell whether the multiplicand is to be 
added into the product window. Thus the unsigned multiply consists of 16 microcycles. In each microcycle the low- 
order bit of the Q register in the least significant slice is tested, if this bit is 1, the multiplicand is added to the partial 
product. If this bit is 0, no addition is performed. Addition, if it occurs, consists of adding the ALU R and S inputs, which 
probably means adding the contents of the RAM location addressed by A to the contents of the RAM location ad- 
dressed by B. If A and B are the R and S ALU inputs, respectively, with the sum returned to the RAM location addressed 
by B, then WE, OEb- OEy. EA. and 10 must all be 0. 
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After the low-order bit of the Q register in the least significant slice has been tested, and a conditional addition has 
been performed, the product space (local RAfVl addressed by B, and the Q register) is downshifted one bit position dur- 
ing the same microcycle. The Carry status following the addition is shifted into the high-order bit of the ALU output for 
the most significant slice. If no addition is performed, then the Carry will equal 0, and will be shifted into the high- 
order ALU output bit of the most significant 2903 slice. This may be illustrated as follows: 

Most Significant Slice 
R input S input 



wn iiU 




C(N+1) = C 



C F3 F2 F1 



SIOO = FO 



A single microinstruction performs the actual unsigned multiplication; however, preceding instructions must load the 
multiplier and multiplicand into their appropriate registers, and must zero the RAM location to be used for the running 
partial product. 

Necessary pin connections in a 2903 configuration that uses the unsigned multiply function are illustrated in 
Figure 8-23. 

The use of status by the unsigned multiply function is straightforward — with the exception of the Zero status which 
propagates the current low-order multiplier bit to all 2903 slices as we have already described. The Carry In, CN, 
must be 0. If it is 1 you get the wrong answer when the multiplicand is added to the product window. The Carry Out, 
C(N-l-4), the Overflow, and the Sign status are all output by the most significant 2903 slice to reflect the result 
of each partial product addition. However, these statuses are useless and should be ignored. 



The 2903 will also perform twos complement multiplication on two 1 6-bit signed binary 2903 TWOS 

numbers to generate a 32-bit signed binary resutt. The algorithm for performing twos com- COMPLEMENT 

plement multiplication is essentially the same as the unsigned multiplication algorithm MULTIPLY 

which we have already described; the same registers are used to hold the multiplier, the FUNCTION 
multiplicand, and results. 

There are two differences between signed and unsigned multiplication; they are: 

1) We must account for the sign bit of the multiplier, which is not a magnitude bit. 

2) Slightly different logic is needed to generate the bit which is shifted into the high-order ALU output from the most 
significant 2903 slice following each downshift. 

The logic of twos complement multiplication using signed binary arithmetic is readily deducible from the unsigned 
multiplication algorithm which we described for the 2901, together with the discussion of signed binary arithmetic 
given in Chapters 2 and 3 of Volume 1. Moreover, you the user cannot modify twos complement multiply logic in any 
way; therefore a detailed understanding of the algorithm is of academic interest only. The algorithms for signed and 
unsigned binary multiplication remain the same until the last microcycle — at which time the sign bit of the 
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multiplier is in the low-order bit of the product space. This may be illustrated as follows: 
Local RAM 
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sign bit, last 
bit of multiplier, 
which has been 
downshifted out 

of Q register 

If the sign bit is 0, then the multiplier is positive and the multiplicand need not be added again to the partial product; 
following the next downshift the multiplication is complete. But if the sign bit is 1, then on the last microcycle the 
multiplicand must be subtracted from the partial product before the final downshift. 

When the Twos Complement Multiply function is executed, following each downshift, the Exciusive-OR of the 
Overflow and Sign statuses is moved into the high-order bit position of the most significant 2903 slice. This en- 
sures that a 1 is shifted into the high-order bit position if addition generated a Carry, or if a negative result must have its 
sign extended. 
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ALU output = [S] + CN if Z = 0. or [R] + [S] + CN if Z = 1 






[F] and [Q] are downshifted one bit position 










MSS means Most Significant Slice 










IS means Intermediate Slice 










LSS means Least Significant Slice 










[S] = S ALU input 










[R] = R ALU input 










[F] = ALU output 










[Q] = Q register contents 










QO = Low-order bit of Q register 










FO = Low-order bit of F register 































Figure 8-23. 2903 Unsigned Binary Multiply Function Pin Connections 

Figure 8-24 illustrates pin connections needed to execute Twos Complement Multiply and Twos Complement 
Multiply Last Cycle special functions. 

The only non-obvious aspect of Figure 8-24 is the generation of the Carry in (CN) to the least significant 2903 slice. 
This Carry In must be until the last microcycle, at which time it must receive the Zero status. We therefore show the 
Twos Complement Multiply Last Cycle instruction code uniquely generating an ENABLE signal which conditions an 
AND gate that generates the CN input. The AND gate passes through the Zero status during the Twos Complement 
Multiply Last Cycle instruction's execution, but at other times the AND gate does not pass the Zero status, generating a 
CN input. This function is provided in the 2904 logic. 

You must execute twos complement multiply instructions in the proper sequence in order to perform twos complement 
multiplication using 2903 devices. You execute the Twos Complement Multiply special function fifteen times, then you 
execute the Twos Complement Multiply Last Cycle special function. 

The two microinstructions which perform the twos complement multiply and the last cycle of the twos complement 
multiply must of course be preceded by microinstructions that correctly load registers and zero the memory word being 
used for the high-order half of the product. 
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Figure 8-24. 2903 Signed Binary Multiply Function Pin Connections 
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2903 TWOS 
COMPLEMENT 
DIVIDE 
FUNCTION 



We will now examine the 2903 Twos Complement divide special function. 

You divide a divisor into a dividend. The answer is called a quotient, and there will be a remainder. 
This may be illustrated as follows: 

Quotient r = Remainder 
Divisor ) Dividend 

Conceptually the algorithm for performing binary division is very straightforward. As for decimal division, you begin at 
the most significant end of the dividend: 

1 1 ... 1 l) 1 00- ■• 1 1 1 

1 10- -1 1 

But when you perform binary division the problem reduces to comparing the magnitude of the divisor and the current 
dividend field: 




Divisor larger, X = 



( 1 1 1 l]" 

Divisor smaller, X = 1-« 1 1- ■ ■ 11 ' 

When performing a twos complement divide we begin by subtracting the divisor from the high-order end of the divi- 
dend: 



10 10 110 1)1 101 001 01 01 1 1 1 01 
>^1 1 1 10 1 



Dividend most significant field^ 10 10 1- 



-Partial remainder 



If the divisor is the smaller number, as it is in the illustration above, then the partial remainder is positive; we add the 
next dividend bit and subtract again: 



10 1011 01)1101001010111101 
10101 10 1 
00100 1011 
1010 110 1 

This is equivalent to upshifting the combined partial remainder and dividend residue one bit position, and then 
subtracting the divisor again: 

1 

10 10 1 1 1 ) 1 1 1 1 1 1J 1 10 1 



Dividend residue 




001001011011110 1 

001001011011110 1-« Upshift combined partial 

-*- 1 1 1 10 1 remainder and dividend 

residue 
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But what happens if you get a negative result after subtracting the divisor from the current dividend field? The answer 
is that you must add the divisor back to the partial remainder before upshifting the dividend one bit position; and then 
subtract the divisor again. But in binary logic this is what happens: 

(Partial remainder + Divisor) x 2 - Divisor 



f 



this is the equivalent of an upshift 

The sequence of operations is equivalent to: 

Partial remainder x 2 - Divisor 

Therefore when you subtract the divisor and get a negative result, you simply upshift the concatenated Partial re- 
mainder and Dividend residue fields one bit position, then subtract the divisor on the next step. 

This is, in essence, the algorithm used by the 2903 to perform binary division, and is called "non-restoring" division. It 
is based on the Twos Complement Divide special function, which performs the following net operations: 

[F] = [S] -I- [R] ifZ = 
[F] = [S] - [R] if Z = 1 

[F], [S], and [R] are the ALU output, S operand and R operand, respectively. 

The Zero status is generated by sign compare logic as the complement of the Exclusive-OR of most significant slice 
high-order ALU output and R operand input bits: 



Z = R3eF3 

Additional required conditions are that lEN be low and one of the Twos Complement Divide special functions be ex- 
ecuted. 

The sign compare level is output at the most significant 2903 Zero status and it is input to the Zero status of intermedi- 
ate and least significant 2903 slices. In effect, the sign compare logic compares the sign of the partial remainder with 
the sign of the divisor. This generates the following logic sequence: 

1) If [F] and [R] signs are the same, the divisor had a smaller absolute magnitude than the dividend field from which it 
was subtracted. Z is therefore 0, so on the next microcycle we get: 

[F] = [S] + [R] 

2) If [F] and [R] signs differ, the divisor had a larger absolute magnitude than the dividend field from which it was 
subtracted. Z is therefore 1, so on the next microcycle we get: 

[F] = [S] - [R] 

The quotient bits are also determined by comparing the sign of the partial remainder with the sign of the divisor If the 
signs differ, the current quotient digit is because the divisor has the larger absolute value: but if the signs are the 
same, the current quotient digit is 1 because the divisor has the smaller absolute value. 

Let us now iooi< at the exact 2903 implementation of the binary division. The two steps defined above do not take 
into account the first step — at which time we have no partial remainder, or ALU output. 2903 division logic therefore 
demands that the absolute magnitude of the divisor be greater than the absolute magnitude of the most signifi- 
cant half of the dividend. To ensure that the divisor does indeed have larger absolute magnitude, the algorithm 
illustrated in Figure 8-25 is recommended in Advanced Micro Devices' literature. We will describe this logic, 
even though other logic could achieve the same desired result. 

In order to compare the absolute magnitude of divisor and dividend, we need to work only with the most significant 
half of the dividend. Comparison instructions destroy the data, therefore we begin by moving the divisor and the most 
significant half of the dividend to temporary buffers — in all probability additional locations in local RAM. 

When moving the divisor to an alternate RAM location we can test the Zero status to see if the divisor is 0. If it is, the 
division must be aborted. 

Next we use the Sign/Magnitude Twos Complement special function (which we have already described) to generate 
positive magnitudes for the copies of the divisor, and the most significant half of the dividend; now we can compare 
these magnitudes without bothering about sign. 

The Sign/Magnitude Twos Complement function, when executed, Generates a positive Overflow status if the data in- 
put is the most negative binary number allowed — in our case -2^ ^. We take advantage of this Overflow status when 
operating on the most significant half of the dividend. If the most significant half of the dividend is -2^ 6, then the 
divisor cannot possibly be larger, so we downshift the entire dividend one bit position and restart. We also check the 
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Overflow status when performing the Sign/Magnitude Twos Complement operation on the divisor. If the divisor is 
-2^6 then it must be larger than the dividend, which is not -2^6, since the dividend test was made first. We therefore 
go straight to the division operation. 

If neither the divisor nor the most significant half of the dividend is -2^^ ^q upshift both numbers one bit position to 
remove the sign bit, then subtract the most significant half of the dividend from the divisor. If the dividend is larger, it 
must be downshifted one bit position — and the test repeated. When the divisor is larger, we are ready to start the divi- 
sion. 

tf you scale the divisor or the dividend, then the quotient must be scaled in compensation. Divisor, dividend and quo- 
tient scaling logic is entirely your responsibility. 

Combining the data preparation and division programs, the sequence of 2903 special functions shown in Table 
8-9 is recommended in vendor literature to perform binary division. Table 8-9 shows a 1 6-bit divisor divided into 
a 32-bit dividend to generate a 16-bit quotient and a 16-bit remainder. 

The instruction sequence preceding the actual division instructions implement Figure 8-26 logic. These instructions 
need no special discussion. But we do need to clarify the manner in which status signals output by the 2903 are 
handled. The 2903 outputs status and data at the same time. For timing details refer to the 2903 microcycle descrip- 
tion given earlier in this chapter. Some 2903 functions require status output by one 2903 slice to be input to other 
2903 slices within the same microcycles; for an example of this look at the way Z is used by the Twos Complement 
Divide special function. Status is output early enough in the microcycle for an output to become an input to another 
2903 slice within the same microcycle. But external logic will not have time to process any 2903 status outputs in the 
process of generating 2903 inputs for the same microcycle. Status output in one microcycle must be processed by ex- 
ternal logic during the next microcycle. In Table 8-9 the comments associated with each microinstruction identify 
relevant status, if any, which is generated during the microinstruction's execution. Comments make clear the fact that 
the generated status must be tested during the next microcycle's execution time. Status output by the 2903 is usually 
tested by microprogram address generation logic. Later in this chapter, when we describe microprogram address 
generation devices, the consequences of testing status while executing the next microinstruction will become self-evi- 
dent. 

The three divide instructions use 2903 local RAM and Q registers as follows: 



Divisor register 



Divisor buffer 



Dividend Most 
Significant 
Half register 



Dividend Most 
Significant 
Half buffer 




Dividend Least 
Significant 
Half register 



Q register 



Remainder 



Quotient 



7 



The divisor and dividend require initial memory locations identified as registers in the illustration above. The divisor 
and the most significant half of the dividend also require temporary buffers. The contents of these buffers are destroyed 
in the process of comparing the divisor and dividend magnitudes. 
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CZjEZ) 



Move the divisor and 
most significant half 
of the dividend to 
temporary buffers 




Perform twos comple- 
ment sign/magnitude 
convention on divisor 
and most significant 
half of dividend in 
temporary buffers 



) 




YES 



Subtract most 
significant half of 
dividend from divisor 



Move least significant 
half of dividend to 
Q register 




YES 



Downshift 
dividend one 
bit position 



Start division 



Figure 8-25. 2903 Binary Division Data Preparation Algorithnn 
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Table 8-9. A Possible 2903 Twos Complement Binary Division Microprogram 



No 


Microinstruction 


EA 


CN 


AO- A3 


B0-B3 


Comment 


18-15 


14-11 


10 


1 


4 


6 











Divisor register 
(RO) 


Divisor buffer 
(R3) 


Copy divisor to temporary buffer. 


2 


4 


6 











Dividend (MS) 
register (R1) 


Dividend (MS) 
buffer (R2) 


Copy dividend most significant half to temporary buffer. 


3 


5 








X 


.0 


X 


Dividend (MS) 
buffer (R2) 


Convert dividend (MS) from twos complement to sign/magnitude version. 
Test OVR externally while next microinstruction is being executed. If OVR is 1 , 
branch to subroutine that downshifts dividend. 


4 


5 








X 





X 


Divisor buffer 
(R3) 


Convert divisor (MS) from twos complement to sign/magnitude version. 
Test OVR externally. If OVR is 1, branch to microinstruction 9. 


5 


9 


4 





X 





X 


Dividend (MS) 
buffer (R2) 


Shift out sign bit of dividend (MS) half in temporary buffer. 


6 


9 


4 





X 





X 


Divisor buffer 
(R3) 


Shift out sign bit of divisor in temporary buffer. 


7 


F 


2 








1 


Dividend (IVIS) 
buffer (R2) 


Divisor buffer 
(R3) 


Subtract sign bit stripped divisor from sign bit stripped dividend (MS) half. 
If Carry = 1 (dividend larger) branch to subroutine that downshifts dividend 
or upshifts divisor. 


8 


6 


6 











Dividend ILS) 
register (R4) 


X 


Copy dividend least significant half to Q register. 


9 


A* 














Divisor register 
(RO) 


Dividend (MS) 
register (R1) 


Double length normalize dividend in MS register and Q register. 


10 


C* 











z 


Divisor register 
(RO) 


Dividend (MS) 
register (R1) 


Execute twos complement divide instruction fourteen times. 


11 


E 











z 


Divisor register 
(RO) 


Dividend (MS) 
register (R1) 


Twos complement divide final instruction. 


•CN 


is conne( 


,ted to Z 


status 


while t 


iese tv\ 


10 special functions 


are being execute 


d. 



Before the actual division begins, the least significant half of the divi(dencl is moved to the Q register The quotient is 
ultimately returned in the Q register and the remainder in the Dividend Most Significant Half register. Taking a simple 
case, if local RAM is used to implement Divisor and Dividend registers and buffers, then we can illustrate local RAM 
and Q registers utilization as follows: 

Initial: 

RO - Divisor 

R1 - Dividend, most significant half 

R2 - Copy of R1 , dividend most significant half 

R3 - Copy of divisor 

R4 - Dividend, least significant half 

Q - Dividend, least significant half 

Final: 

R1 - Remainder 
Q - Quotient 

The Q register, which initially holds the least significant half of the dividend, ultimately holds the quotient. As the divi- 
dend is upshifted out of the Q register and into the Dividend Most Significant Half register, quotient bits get shifted into 
the Q register via QO. 
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If you look again at Table 8-9, you will see that the actual division operation executes three functions: 

1) The Double Length Normalize function, which serves as the first divide function. 

2) The Twos Complennent Divide function; this function is executed N-2 times, where N is the number of divisor and 
quotient bits. 

3) A final Twos Complement Divide Correction function completes the division. 

Necessary pin connections for the Double Length Normalize function are given in Figure 8-21. Figure 8-26 
shows necessary pin connections for the Twos Complement Divide and Twos Complement Divide Correction 
functions. 

Zero status logic is used to transmit sign compare information from the most significant 2903 slice to intermedi- 
ate and least significant slices. The level transmitted is the complement of the Exclusive-OR of the most significant 
bits of the ALU output and R operand input. This may be illustrated as follows: 



R3 R2 R1 RO 



S3 S2 SI SO 



HU uu 




TTTJ 

F3 F2 F1 FO 



Z = R3 ® F3 

This Z status logic works only when an A or C special function code is input via 18-15, and lEN is simultaneously 
low. The Z status also becomes the CN input to the least significant slice in order to neutralize CN within the ALU 
functions performed. This may be illustrated as follows: 

[F] = [S] + [R] -I- CN if Z = 

so [F] = [S] + [R] if CN = Z 

[F] = [S] - [R] - 1 + CN if Z = 1 

so[F] = [S]-[R] if CN =Z 

The Q register and ALU register are connected so that an upshift causes the high-order bit of the Q register to be input 
to the low-order ALU bit. The high-order ALU bit is lost, and the next quotient digit is shifted into the least significant 
bit of the Q register. This may be illustrated as follows: 



Lost bit 



SI03 




ALU register 



TSIOO 



QI03 



Q register 



The level actually output at SI03 is also R3® F3. This becomes the next bit shifted into the quotient. 

The final Twos Complement Divide Correction function forces a 1 into the low-order quotient bit, leaving the remainder 
adjusted accordingly. 
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F3®R3 



Q3, MSS 



F3 + R3 



QI03 QlOO 

SI03 SIOO 

C(N+4) CN 

OVR 

W/MSS 
N MSS 

2903 

LSS 

WE 



+5V 
Q 




+5V 



QI03 
SI03 
C(N+4) 



QlOO 

SIOO 

CN 



IS 
2903 
W/MSS 



LSS 



WE 



+5V 

o 



QI03 
SI03 
C(N+4) 



QlOO 

SIOO 

CM- 



IS 
2903 
W/MSS 



LSS 



WE 



+5V 
O 



QI03 
8103 



QlOO 
SIOO 
CN 



<3=^ 



C(N+4) 

LSS 
2903 
W/MSS 



LSS 



WE 



Q. 



ENABLE - 



ALU output = [S] + [R] + CN if Z = 0, or [S] - [R] + CN - 1 if Z = 1 

[Q] is upshifted on all microcycles 

[F] is upshifted on twos complement divide, but not on twos 
complement divide last microcycle. 
ENABLE is high on last cycle only 

MSS means Most Significant Slice 

IS means Intermediate Slice 

LSS means Least Significant Slice 

[S] = S ALU input 

[R] = R ALU input 

[F] = ALU output 

[Q] = Q register contents 

Q3, R3 and F3 are most significant bits of Q register, R ALU input and ALU output 



Figure 8-26. 2903 Signed Binary Twos Complement Divide Pin Connections 

Merely understanding the pin connections and functions shown in Figure 8-25 is quite straightforward. Understand- 
ing how binary division is performed using these pin connections, and the three binary division functions, is not self- 
evident. Let us therefore take a very simple example and analyze divide logic in conjunction with this example. Con- 
sider the following simple division: 



24 



10 



18 



16. = 3 remainder 3 



'10 '16 

We have a 4-bit divisor and an 8-bit dividend which generate a 4-bit quotient and a 4-bit remainder. We must therefore 
execute the Double Length Normalize function, followed by two Twos Complement Divide functions, and a Twos Com- 
plement Divide Correction function. 
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For Step 1 we execute the Double Length Normalize function. This upshifts the dividend and generates the sign of the 
quotient at SI03 of the most significant slice. The quotient sign bit gets shifted into the low-order Q register bit. Logic 
may be illustrated as follows: 



Stepi 


[F] 


[R] 


[S] 


[Q] 


SI03 


z 


Initial 


? 


0111 


0001 


1 000 


? 


? 



/////// 



Final 0001 0111 0011 00 0-* — 

SI03 is the Exclusive-OR of the most significant slice ALU output and R operand input bits. This may be illustrated as 
follows: 



Step 1 [F] [R] [S] [Q] 

Initial ? 111 1 10 

Final 0001 0111 0011 0000 




SI03 
? 





This SI03 logic says that when the divisor and the dividend have the same sign, the quotient is positive; the quotient is 
negative when the divisor and the dividend have opposite signs. What is not self-evident is the fact that we have 
multiplied the dividend by two before starting to work with the divisor. In consequence, we must finally upshift the 
quotient and thie remainder to generate answers that stand numerical comparison. 

Moving on to Step 2, we execute the Twos Complement Divide function for the first time. The Zero status is 1: 



Step 1 [F] [R] [S] [Q] 8103 

Initial ? 0111 0001 1000 ? 



Final 0001 0111 0011 0000 




Therefore, we subtract the divisor from the high-order four dividend bits. This may be illustrated as follows: 

Step 2 [F] [R] [S] [Q] SI03 Z 

Initial 0001 0111. 011 0000 1 




Final 1100 0111 1000 0000-« — 



This step is very logical. It is equivalent to initially subtracting the divisor from the dividend in any decimal division: 

25)237642 . . . 
25 
-2 
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In our binary example the divisor is larger than the dividend, even though the dividend has been upshifted; therefore 
the next quotient bit shifted into the Q register is 0. is indeed output by the most significant slice at SI03: 



Step 1 [F] [R] [S] [Q] 

Initial 0001 0111 0011 0000 
Final 1100 0111 10 00 0000 




SI03 







In Step 3 the Twos Complement Divide function is executed a second time. The Zero status is now 0: 

Step 2 [F] [R] [S] [Q] SI03 Z 

Initial 0001 0111 0011 0000 1 

Final 1100 0111 1000 0000 _0 




Therefore, during Step 3 we add the divisor to the high-order four bits of the shifted dividend. This addition, and the 
subsequent upshift, may be illustrated as follows: 

Step 3 [F] [R] [S] [Q] SI03 Z 

Initial 1100 01111000 0000 




Final 1111 0111 1110 0000 



Adding the divisor to the upshifted dividend is also self-evident. We got a negative answer during Step 2, therefore (as 
described earlier) we must now compensate by adding the divisor to the upshifted dividend. The dividend is still 
smaller than the divisor, so once again SI03 outputs at the most significant 2903 slice: 

Step 3 [F] [R] [S] [Q] SI03 Z 

Initial 1100 0111 1000 0000 

Final 1111 0111 1110 0000 _^0 _*^0 




and zero gets shifted into the Q register to become the next quotient bit. 
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Finally, in Step 4 we execute a Twos Complement Divide Correction function. Once again we test the Z status, which is 
0, therefore we add the divisor to the high-order four bits of the upshifted dividend. Together with the final shift this 
may be illustrated as follows: 

Step 4 [F] [R] [SI [QI SI03 Z 

Initial 1111 0111. 1110 0000 




Forced input 



During the final shift a 1 is forced into the quotient to become the quotient low-order bit. The four high-order dividend 
bits do not change. Thus our final answer is: 

Quotient = 0001 
Remainder = 0101 

In order to test the numeric accuracy of our answer we must upshift one bit position: 

Quotient = 0010 
Remainder = 1010 

Thus, the answer is 2 with a remainder of Ai6 — which is not 3 with a remainder of 3, but it is correct. 

Your external logic (2904) must upshift the quotient and the remainder, if your algorithm demands it, and must adjust 
the quotient and the remainder if your algorithm requires the remainder to be less than the divisor. 
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THE 2902 CARRY LOOK-AHEAD DEVICE 

This device serves just one function: when performing binary addition or subtraction using cascaded 2901 or 
2903 systems, it creates parallel carry inputs for 4-bit slices beyond the least significant slice. Carry Look- 
Ahead logic has been described in detail in Volume 1, Chapter 4. We will therefore provide a simple summary of 
the 2902 device in this chapter, stating its logic functions, but omitting Carry Look- Ahead theory. 

The 2902 is packaged as a 1 6-pin DIP. All signals are TTL-level compatible and a single +5V power supply is required. 
The 2902A is a faster version of the 2902. 

2902 PINS AND SIGNALS 

Figure 8-27 illustrates pins and signal assignments for the 2902 Carry Look-Ahead device. Figure 22-28 shows 
a 2902 device connected to four parallel 2901 devices. If you replace the 2901 devices with 2903 devices, con- 
nections between the 2902 and the 2901 or 2903 devices do not change. 




Pin Name 


Description 


Type 


PO, R, P2, P3 


Carry Propagate 


Input 


GO, G1,G2, G3 


Carry Generate 


Input 


P 


Carry Propagate 


Output 


G 


Carry Generate 


Output 


CN 


Carry in 


Input 


C{N-t-1), C(N+2), C(N+3) 


Intermediate carry 


Output 


Vcc. GND 


Power, Ground 





Figure 8-27. 2902A Carry Look-Ahead Generator Signals and Pin Assignments 
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QO 03 

RAMO RAM3 
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2901 



CN 



C(N+4) 

OVR 

F3 

F = 



nj: 



YO- Y3 



D4 - D7 ' 



1 



QO Q3 

RAMO RAM3 

G 

2901 ^ 

C(N+4) 

OVR 

F3 

CN F = 



IT 



Y4- Y7 



D8 - D1 1 



H 



QO Q3 

RAMO RAM3 

G 

2901 P 

C(N+4) 

OVR 

F3 

CN F = 



D12 -015 



U 



Y8 - Y1 1 



I2IS is:i5 ISIIS ISIS 



CN 



2902 



C(N+1) C(N+2) C(N+3) 



1 



QO Q3 

RAMO RAM3 

G 

2901 ^ 

C(N+4) 

OVR 

F3 

CN F = 



U 



Y12- Y15 



-Q15 I/O 
-RAMI 5 I/O 




Figure 8-28. Four 2901s in a 16-Bit CPU Using the 2902 for Carry Look-Ahead 

GO . G1, G2, and G3 are Carry Generate inputs received fronn 2901 or 2903 slices. GO is the least significant slice and 
G3 is the most significant slice These 6 inputs are generated by 2901 and 2903 devices as shown in Table 8-10. 

PO, PI, P2, and P3 are Carry Propagate signals received from four 2901 or 2903 slices. These signals are gener- 
ated as shown in Table 8-10. 

In a 2901 or 2903 configuration with four slices. G3 and P3 are unused, as illustrated in Figure 8-28. This is logical; 
there are no higher-order devices to receive Carry Look-Aheads, therefore generate and propagate outputs from the 
most significant 2901 or 2903 slice are not meaningful. In fact, the most significant 2903 slice does not output a Carry 
Generate or Propagate signal. 

If you have fewer than four 2901 or 2903 slices in a configuration, then you leave unconnected the high-order 2902 G 
and P inputs. For example, an 8-bit Central Processing_Unit configured with two 2901 slices would receive PO and GO 
inputs from the least significant slice, jnd th£t is all. PI and G1 inputs would not be received from the most significant 
slice since the most significant slice P and G outputs are always meaningless. 

C(N-H), C(N-l-2), and C(N-H3) are the three Carry levels output by the 2902 device. These signals should be con- 
nected to the CN inputs of the 2901 or 2903 slices as illustrated in Figure 8-29. 
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Table 8-10. P and G Generation Logic for 2901 and 2903 Devices 



'543 



Function 



C(N-l-4) 



OVR 



G3 + P3G2 + P3P2G1 



R + S 



P3P2P1P0 



C4 



C3 ® C4 



+ P3P2P1G0 



S-R 



■Same as R + S equations, but substitute R; for Rj definitions in definitions- 



R -S 



Same as R + S equations, but substitute Sj for Sj in definitions 



R VS 



Low 



P3P2P1P0 



P3P2P1PO + CN 



P3P2P1P0 + CN 



R A S 



Low 



G3 + G2 + Gi + Gq 



G3 + G2 + Gi + Gq +CN 



G3 + G2 + Gi + Gq + CN 



R A S 



Low 



■Same as R -t- S equations, but substitute Rj for R; in definitions- 



R(©S 



■Same as R®S, but substitute R; for Rj in definitions- 



R(?>S 



G3 + G2 + Gi + Gq 



G3 + P3G2 + P3P2G1 

+ P3P2P1G0 



G3 + P3G2 + P3P2G1 
+ P3P2P1P0 (Go + CN) 



See note 



Note: (P2 + G2P1 + G2G1P0 + G2GiGoCN]©[P3 + G3P2 + G3G2P1 + G3G2G1P0 + G3G2G1G0CN] 
Definitions (+ = OR,® = Exciusive-OR) 

Pq = Ro + So Go = RoSq 

P-l =Rl + Si Gi =RiSi 

P2 = R2 + S2 G2 = R2S2 

P3 = R3 + S3 G3 = R3S3 

C4 = G3 + P3G2 + P3P2G1 + P3P2P1G0 + P3P2P1P0CN 
C3 = G2 + P2G1 + P2P1G0 + P2P1P0CN 



CN is an input signal. This is logical, since the least significant 2901 or 2903 slice can receive any Carry In. 

The P and G outputs from the 2902 device allow you to cascade more than one 2902 device, and thus compute 
look-ahead carries for more than four parallel 2901 or 2903 slices. Figure 8-29 shows pertinent pin connec- 
tions for a 48-bit CPU generated using twelve 2901 or 2903 devices. 

Figure 8-30 illustrates the actual logic used by the 2902 device to generate its output signals from its input 
signals. 
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■To C48 



Figure 8-29. Carry Look-Ahead Scheme for 48-Bit CPU Using Twelve 2901s 




Figure 8-30. 2902 Carry Look-Ahead Signal Generation Logic 
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THE 2909 AND 2911 MICROPROGRAM SEQUENCERS 



These two devices control the sequence in which microinstructions are fetched from memory and transmitted 
to 2901 or 2903 microprocessor slices. The 2910, a more capable microprogram sequencer, is described later in 
this chapter. 

The 2909 Microprogram Sequencer is packaged as a 28-pin DIP. The 291 1 Microprogram Sequencer is 
packaged as a 20-pin DIP. Both devices use bipolar technology and have TTL-level compatible signals. Both 
devices use a single +5V power supply. 

The 291 1 Microprogram Sequencer is a subset of the 2909. The 291 1 has one less data input option and no out- 
put mask option. The two devices are otherwise identical. 

THE PURPOSE OF MICROPROGRAM SEQUENCER LOGIC 

Figure 8-31 functionally illustrates microinstruction generation logic that might precede 2901 or 2903 
microprocessor slices in a Central Processing Unit, or equivalent system. We will explain the purpose of 
microprogram sequencer logic before describing the devices themselves. This discussion of microprogram se- 
quencer logic assumes that you understand the relationship between microinstructions, a microprogram, and 
macroinstructions. If you do not understand these relationships, then refer to Volume 1, Chapter 4. 

Beginning at the top of Figure 8-31, a macroinstruction will be received and stored in a Macroinstruction register. 
When describing microprocessors and Central Processing Units in general, we refer to the Macroinstruction register 
simply as the "Instruction register". This register holds the assembly language instruction object code that is to be ex- 
ecuted. 

A macroinstruction object code will normally have two components: an instruction definition, and associated data. 
The instruction definition, frequently referred to as an operation code (or op-code), identifies the actual CPU operations 
which are to occur. The additional data may be used in a variety of ways to identify sources and destinations, to con- 
tribute external memory addresses, or to be interpreted as immediate data. 

Events which are to occur within the CPU in response to a macroinstruction's execution are defined as one or more 
microinstructions. These microinstructions will be held in a high-speed read-only memory (ROM) or programmable 
read-only memory (PROM). The op-code portion of a macroinstruction identifies the microinstruction(s) t.o be executed 
in response to the macroinstruction. The additional information portion of the macroinstruction is simply held available 
until required by logic operations resulting from microinstruction execution. This may be illustrated as follows: 

Macroinstruction 
Object Code 




Information used 
by microinstructions 
in the course of 
execution 



Microinstructions 
to be executed 
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Figure 8-31. Function of Microprogram Sequencer Logic in a 2901 or 2903 Based System 
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Macroinstruction object codes have been described in considerable detail in Volume 1, Chapter 7. This discussion 
ennphasizes the fact that macroinstruction object codes are selected to optimize Central Processing Unit operations, 
without regard to microprograms, or how microprograms may be stored in a memory device. This being the case, there 
is no chance that the op-code portion of any macroinstruction will have a bit pattern that addresses the correct 
microinstruction, or initial microinstruction that must be executed in response to the macroinstruction's execution. In- 
stead, a mapping read-only memory or a programmable logic array is used as an address translator. The mapping ROM 
or PLA treats the op-code portion of the macroinstruction as an input. In the ROM, the actual microprogram starting ad- 
dress is stored at the location addressed by the op-code bit pattern. Conceptually, this may be illustrated as follows: 



Assembly Language 
Object Code 



Op Code 



Data 




This actual bit pattern 
Is treated as a memory 
address In mapping ROM 



Microinstructions 
to be executed 



The contents of the 
addressed memory 
word is the address 
of the first microinstruction 
in microprogram ROM 




The size of the mapping ROM and the width of the address which it outputs depend on the size of the microprogram — 
that is to say, the length of the microprogram in terms of the number of microinstructions. This may be illustrated as 
follows: 



Microinstruction 

bit width has no 

effect on mapping 

ROM size 




Number of 
microinstructions 
determines size 
of mapping ROM 



If, for example, 256 or fewer microinstructions constitute the entire microprogram, then an 8-bit address can be output 
by the mapping ROM, irrespective of whether the microinstructions are 1 6 bits wide, 64 bits wide or have any other bit 
width. But, if the total length of the microprogram were 1024 microinstructions, then a 10-bit address would have to be 
output by the mapping ROM. 
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If every macroinstruction resulted in the execution of a single microinstruction, then there would be no need for 
2909/2911 Microprogram Sequencers. The mapping ROM could output a single address to the microprogram ROM. 
The contents of the addressed microprogram ROM would be output to the Microinstruction register — to become the 
microinstruction that enables operations required by the macroinstruction. 

But it is most unlikely that the Central Processing Unit's assembly language will consist of instructions that are all pri- 
mitive enough to be implemented via a single microinstruction. In particular, as Central Processing Units become more 
complex, an ever larger number of microinstructions may have to be executed in response to a single macroinstruction 
execution; and the sequence in which these microinstructions are stored may also become more complicated, the 
2909 and 291 1 Microprogram Sequencers provide the logic which takes you from the initial microinstruction through 
the microprogram. 

There is one very important conceptual aspect of the 2909 and 291 1 Microprogram Sequencers which must be clearly 
understood. These Microprogram Sequencer devices are, like the 2901 and 2903, cascadable 4-bit devices. But there is 
no relationship between the number of 2909/291 1 devices which are cascaded. 2901 or 2903 devices are cascaded to 
give you the required CPU word width. Two 2901/2903 devices generate an 8-bit word; four 2901/2903 devices 
generate a 16-bit word; eight 2901/2903 devices generate a 32-bit word, etc. 2909 or 291 1 devices are cascaded to 
address the required length of microprogram memory. The number of 2909 or 291 1 devices cascaded together is in no 
way influenced by the width of the microinstruction, or the width of the CPU word. For example, if the microprogram 
has 256 or fewer microinstructions, two 2909 or 291 1 devices cascaded together are sufficient. This holds true 
whatever the microinstruction width may be, and whatever the CPU word width may be. Thus the number of parallel 
2901 or 2903 slices has no bearing whatsoever on the number of parallel 2909 or 291 1 devices. You cannot even 
generalize by stating that there will be a tendency to require more 2909/2911 devices as the number of parallel 
2901/2903 devices increases. Rather, the width of the microinstruction will increase with the number of 2901/2903 
devices and, as we have already stated, the width of a microinstruction has no bearing on the length of the 
microprogram, or the number of parallel Microprogram Sequencer devices that will be needed. 

2909/291 1 MICROPROGRAM SEQUENCER PINS AND SIGNALS 

Pins and signal assignments for the 2909 and 2911 IVIicroprogram Sequencers are illustrated in Figure 8-32. 
These signals are most easily understood in conjunction with the functional logic illustrations for the two 
devices which are given in Figures 8-33 and 8-34. 

Central to the logic of 2909 and 291 1 Microprogram Sequencers is the Output Multiplexer, 2909/291 1 

which receives four inputs. SO and SI are two control inputs that select an output as OUTPUT 

follows: SELECT 



SO SI Output Multiplexer Source 

Microprogram Counter 

1 Address register 

1 Stack 

1 1 Direct inputs (via D0-D3) 

We will for the moment ignore the Microprogram Counter and Stack, two data storage areas whose functions will be 
described shortly. 

D0-D3 are four data input lines. Data input via these four lines can be selected^y the Output 
Multiplexer and output immediately (if SO and SI are both high). 

Data input via R0-R3 is held in the Address register. Timing for Address register access may be 
illustrated as follows: 



2909/291 1 
IMMEDIATE 
DATA INPUT 



2909/291 1 

ADDRESS 

REGISTER 



R0-R3 



Address 
Register 
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■Y1 SO- 



2911 




Pin Name 
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Type 


R0-R3 


Address register input 
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D0-D3 


Data input 


Input 
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Combined Address register and data input 
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Zero Address output control 
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FE 
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Figure 8-32. 2909 and 2911 Microprogram Sequencer Pins and Signal Assignments 
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Figure 8-33. 2909 Microprogram Sequencer Functional Logic 
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Figure 8-34. 2911 Microprogram Sequencer Functional Logic 
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2909/291 1 

DATA 

OUTPUT 



As illustrated above, the Address register enable signal RE must be low before data can be written into the Ad- 
dress register via R0-R3. l_f_RE is low, then data is written into the Address register when the clock signal CP makes its 
high-to-low transition. But RE has no effect on Address register output. Whether RE is low or high, the Address register 
contents are transmitted to the Output Multiplexer. 

The 2911 shares D and R inputs. Data input at R/D0-R/D3 will be written into the Address register if RE is low, and 
will be output via the Output Multiplexer if SO and SI are both high. 

Multiplexer output lines Y0-Y3 have their own enable signal OE. If this signal is high, Y0-Y3 
outputs are floated. This allows you to disconnect Microprogram Sequencer devices from the 
microprogram ROM, something you may do when switching to an external tester. 

The 291 1 has one set of conditioning logic on the Y outpu ts. The 2909 has two sets of condition- 
ing logic on the Y outputs. Both devices have a ZERO input which, when lo w, uni laterally 
forces the four lines YO, Y1, Y2, and Y3 to output 0. Frequently you will use the ZERO line as a 
restart — with an initialization microinstruction sequence origin at microinstruction number in 
the microprogram ROM. The 2909, but not the 291 1, has four mask signals, ORO, 0R1. 0R2, 
and 0R3, which can individually force YO, Y1, Y2, and Y3, respectively, low. Typically you 
will use the mask signals to implement conditional logic. For example, we have already seen how 
the Overflow status (OVR), output by the most significant 2901 and 2903 slice, signals an over- 
flow or "exceptional" condition. By tying the Overflow status to ORO, you can implement 
microinstruction pairs. The Output Multiplexer outputs a low-order microinstruction address via YO, which ORO can 
override and convert to 1. For an 8-bit microprogram address this may be illustrated as follows: 



2909/291 1 
OUTPUT 
ZERO 
CONTROL 



2909 

OUTPUT 

MASK 



XXXXYYYO 



•Output by high-order 2909 
■ Output by low-order 2909 



XXXXYYYO' 
XXXXYYY 1> 



ORO to low-order 2909 can change this address bit to 1 

■ Microinstruction executed if OVR = 

■ Microinstruction executed if OVR = 1 



Of course, having a mask line associated with every microinstruction address output line lets you generate more com- 
plex conditional logic schemes than the simple illustration above. 

There are two internal locations within the 2909 and the 2911 which can hold addresses. These are the 
Microprogram Counter and the Stack. 

Let us first look at the Microprogram Counter. This location is equivalent to the typical Centra 
Processing Unit Program Counter. 



2909/2911 

MICROPROGRAM 

COUNTER 



When SO and SI are both low. Microprogram Counter contents are read by the Output Multiplexer, and are output via 
Y0-Y3. 

New data is written into the Microprogram Counter whenever data is input from the Output Multiplexer, whether or not 
the Microprogram Counter was selected as the Output Multiplexer input. Data written back to the Microprogram 
Counter is taken from the Y0-Y3 path following the OR and AND gates. Therefore, if you use either of the output condi- 
tioning gates, you will also modify the Microprogram Counter contents. This, of course, is no different to a Central Pro- 
cessing Unit's Program Counter, which is also modified by a restart or jump instruction. 



2909/2911 
INCREMENTER 



Data being written back to the Microprogram Counter passes through an Incrementer. The Incre- 
menter adds the CN level to data which is on its way to the Microprogram Counter. Thus if 
CN is low, the Incrementer passes data through unmodified; but the data is incremented if CN is 
high. An Incrementer overflow generates a high C(N+4) output. 

Let us look at the various ways in which you may use Microprogram Counter logic. 

In the simplest case, you may wish to sequentially access a number of microinstructions. 

You can begin the sequence by inputting the first microinstruction address to the Address register 
via R0-R3, or as immediate data via D0-D3. Remember. 2909 and 291 1 devices are cascadable; 
therefore we are not limited to 4-bit addresses. The initial address, when output by the Output 
Multiplexer, also gets written to the Microprogram Counter. Assuming that CN is high, the address written into the 



2909/2911 

SEQUENTIAL 

ADDRESSES 
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Microprogram Counter will be one more than the starting address input via R0-R3 or D0-D3. For a number of subse- 
quent microcycles, you will continue to select the Microprogram Counter, leaving CN high, so that Microprogram 
Counter contents are incremented on each microcycle. Selecting addresses arbitrarily, this sequence may be illustrated 
as follows: 



D0-D3 


SO 


SI 


CN 


Y0-Y3 


M 
Cou 


icroprogram 
nter Contents 


30 
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XX 
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32 


XX 
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32 




33 


XX 








1 


33 




34 



etc. 



etc. 



XX represents "don't care" inputs. 



There are some non-obvious problems that can occur when you generate sequential microinstruction addresses using 
Program Counter logic as illustrated above. 

The next very simple microprogram counter sequence involves the re-execution of a single 
microinstruction — as you may do while performing a normalize or twos complement divide 
operation using the 2903 special functions. If the Output Multiplexer selects the Microprogram 
Counter contents while CN is input low, then the Microprogram Counter contents will not change 
on succeeding microcycles — and the same microinstruction will be executed repeatedly. 

You can skip a microinstruction with an even address within an otherwise consecutive in- 
struction sequence. To do this you keep CN high, so that the Microprogram Counter increments 
on each microcycle, but you input a high ORO mask bit in order to skip an instruction. This may be 
illustrated as follows: 
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38 address bit to 1. 
39 

etc. 



You can also use mask bits to jump between microprogram pages. For example, within a 256- 
microinstruction program you can jump in sixteen microinstruction increments by inputting a 
high signal at the ORO mask bit of the high-order 2909 slice. This may be illustrated as follows: 
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00 1 1 
00 1 1 


1 

1 
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01 00 
010 1 
110 
0111 



By applying high inputs to other mask bits you can span almost any number of microinstructions in a single jump. 

The 2909/2911 Stack has four locations. (2909/2911 

STACK 



A Stack Pointer identifies the currently selected Stack location. If the Output Multiplexer 

receives SO low and SI high, then it reads the contents of the currently selected Stack location 

and outputs this data via Y0-Y3. This output address, like all other output addresses, passes through the Incrementer 

and is loaded into the Program Counter. 
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You modify the Stack Pointer address using the FE and PUP signals. FE must be low in order to modify the Stack 
Pointer. FE does not have to be low in order to output data from the Stack to the Output Multiplexer. 

When FE and PUP are both low, the Stack Pointer decrements on the low-to-high transition of CP. Timing may be il- 
lustrated as follows: 




PUP 



If FE is low and PUP is high, the Stack Pointer is incremented, then the contents of the Microprogram Counter are 
loaded into the newly addressed Stack register. Timing may be illustrated as follows: 




PUP 



increment 
Stack 
Pointer 



Write 

Microprogram 

Counter 

contents to 

Stack 



The address in the Program Counter which gets written into the newly addressed Stack register will be the address 
which was output by the Output Multiplexer — incremented by one, assuming that CN is high. This enables traditional 
subroutine call and return logic, as we will see soon. 

The Stack Pointer is a roll-over counter. That is to say, it will decrement from to 3: 



and it will increment from 3 to 0: 



*2— 1 -*0— 3— 2— 1 ^0—3- 



»2-*3— 0— 1 ^2— 3-*0— 1 —1- 



This is normally not advantageous. 

Let us loolc at some of the address sequences which can be generated using the Stacic. 



8-101 



Consider first a typical subroutine call — in the classical assembly language sense. The 2909/2911 

microinstruction which causes the subroutine call increments the Stack Pointer. Assuming that SUBROUTINE 

CN is high, the address of the microinstruction which causes the subroutine call is incremented by CALL 

one, written into the Microprogram Counter, and thence to the newly addressed Stack register, to 

the address of the microinstruction to which execution will return at the end of the subroutine. This sequence may be 

illustrated as follows: 




With reference to the illustration above, the microinstruction which causes the subroutine call is arbitrarily assumed to 
reside in microprogram read-only memory location A2-|g. Therefore the subroutine call begins with the Microprogram 
Sequencer outputting address A2i 6, as illustrated above by (T) 

For the microinstruction in location A2i 5, only those bits that affect the Microprogram Sequencer are of interest to us. 
These bits cause the Microprogram Sequencer to receive high inputs at CN and PUP, with a low input at FE. This 
microinstruction will also provide the address for the next microinstruction, arbitrarily assumed to be 2E-\q at (§) in 
the illustration above. But this address will be output on the next microcycle. On the current microcycle, CN causes the 
current address (A2-15) to be incremented to ASjr. This is shown above at @ .The new incremented address A3i 5 
is written to the Microprogram Counter; see (§) above. Since FE is low and PUP is high, the Stack Pointer is incre- 
mented ( © above) and the current Microprogram Counter contents, which is AS-jg, is saved in the Stack. 

On the next microcycle the address 2E-|6 will be output, initiating the subroutine's execution. When the subroutine 
completes execution, it has the return address ASig stored at the Stack register identified by the Stack Pointer. 
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The final instruction of the subroutine must execute a Stack PUP and cause the Output Multiplexer to select the Stack 
as its input. This requires SI to be high while SO, FE, and PUP are all low. The Output Multiplexer will read A3i6 ^rom 
the Stack and output this address next. A3i6 'S incremented to A4i6 and returned as the new Microprogram Counter 
contents. The Stack Pointer decrements. Thus a classical Stack-Oriented Return-from-Subroutine has been executed. 

A subroutine can consist of a single microinstruction. If you look again at the subroutine call illustration given earlier, 
the first instruction of the subroutine, which in our illustration will be the instruction stored at location 2E15, has 
nothing said about its Microprogram Sequencer bits. If this instruction causes a Return-from-Subroutine, then you have 
created a single-microinstruction subroutine. 

Using the Stack you can nest subroutines to a depth of four. In most microprograms, nesting 
to a depth of four is perfectly adequate. 



2909/291 1 

SUBROUTINE 

NESTING 



2909/291 1 
MULTIPLE 
JUMP 



A computed multidestination jump is easily implemented using a 2909 or 291 1 Microprogram 
Sequencer. A 16-way jump to individual instructions can be achieved by inputting data via ORO- 
0R4 to the least significant 2909/291 1 , while generating more significant portions of the address 
from some other location, such as the Address register. 

2909/291 1 SYNC/ENABLE LOGIC 

There are innumerable ways in which the Sync/Enable logic portion of Figure 8-31 could be designed. At its 
most elementary level, 2909/291 1 control signals will be generated (possibly from a read-only memory) based 
on Microinstruction register outputs which become a read-only memory address. This may be illustrated as 
follows: 



Enable/Select 




Microinstruction 
Register 



A 1 2-bit wide read-only memory would be required in the illustration above to generate eleven input signals needed by 
the 2909/291 1 , plus an Enable/Select signal for the R input 2-IN MUX. (The clock signal CP could not be generated by 
a ROM.) It would be possible to generate 4096 different combinations of 1 2 signals. Very few of these possibilities will 
ever be encountered. In all probability, a maximum of 32 different signal combinations may be seen, in which case a 32 
X 12-bit read-only memory will suffice, with a 5-bit address provided by the Microinstruction register. Each 
microinstruction stored in the microprogram ROM will then contain a 5-bit address field; the address field selects one 
of the 32 signal combinations that define the next step of Microprogram Sequencer control inputs. Thus we are able to 
achieve address continuity within a microprogram. In many applications, the 29811 A provides this function. 

But in Figure 8-31 three sets of inputs to the Sync/Enable logic section are shown. 

The "logic sequence and enable" control emanating from the Microinstruction register becomes the 5-bit address 
which we have already described. 
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Table 8-1 1. The 2903 Twos Complement Binary Division Microprogram Subroutine from Table 8-9, 
with 2911 Addressing Microinstruction Fields Added 



No 


Microinstruction 


EA 


CM 


AC -A3 


BO- B3 


Comment 


18-15 


14- 11 


10 


1 


4 


6 











Divisor register 
(RO) 


Divisor buffer 
(R3) 


Copy divisor to temporary buffer. 


2 


4 


6 











Dividend (IVIS) 
register (R1) 


Dividend (MS) 
buffer (R2) 


Copy dividend most significant half to temporary buffer. 


3 


5 








X 





X 


Dividend (US) 
buffer (R2) 


Convert dividend (MS) from twos complement to sign/magnitude version. 
Test OVR externally while next microinstruction is being executed. If OVR is 1 , 
branch to subroutine that downshifts dividend. 


4 


5 








X 





X 


Divisor buffer 
(R3) 


Convert divisor (MS) from twos complement to sign/magnitude version. 
Test OVR externally. If OVR is 1, branch to microinstruction 9. 


5 


9 


4 





X 





X 


Dividend (MS) 
buffer (R2) 


Shift out sign bit of dividend (MS) half in temporary buffer. 


6 


9 


4 





X 





X 


Divisor buffer 
(RS) 


Shift out sign bit of divisor in temporary buffer. 


7 


F 


2 








1 


Dividend (MS) 
buffer (R2) 


Divisor buffer 
(R3) 


Subtract sign bit stripped divisor from sign bit stripped dividend (MS) half. 
If Carry = 1 (dividend larger) branch to subroutine that downshifts dividend 
or upshifts divisor. 


8 


6 


6 











Dividend (LS) 
register (R4) 


X 


Copy dividend least significant half to Q register. 


9 


A* 














Divisor register 
(RO) 


Dividend (MS) 
register (R1) 


Double length normalize dividend in MS register and Q register. 


10 


€• 











z 


Divisor register 
(RO) 


Dividend (MS) 
register (R1) 


Execute twos complement divide instruction fourteen times. 


11 


E 











z 


Divisor register 
(RO) 


Dividend (MS) 
register (R1) 


Twos complement divide final instruction. 


•ON 


is connec 


ted to Z 


status 


while tt 


lese tw 


special functions 


are being execute 


d. 
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Table 8-11. The 2903 Twos Complement Binary Division Microprogram Subroutine from Table 8-9. 
with 2911 Addressing Microinstruction Fields Added (Continued) 



Microinstruction bits covoring 2003 and two 201 1 input 
(Bit positions are arbitrary and have no significance) 



18 17 16 15 14 13 12 II 10 EA CN A3A2A1 A0B3B2B1 BO 



D7D6D5D4D3D2D1D0RES1 SO 



In CN FE S! 



2011 Addressing Operations 



010001100 0000001 1 

4 6 RO R3 

010001100 000010010 

R1 R2 



010100000 X0XXXX001 1 
R3 



100101000 X OXXXX001 1 
4 R3 



011001100 00100XXXX 

6 6 R4 

101000000 0000000 1 

A RO R1 

110000000 X00000001 

C RO R1 

111000000 0X00000001 

RO R1 



AAAAAAAA 0001 1 1 X 
Abort Address 111 

XXXXXXXX10Z1 1 1 X 

1 111 

XXXXXXXX1001 1 1 X 

10 111 

SSSSSSSS100111X 



Scale Dividend 111110 1 

Subroutine 

BBBBBBBB100111X 



Microinstruction 1 1 1 1 1 1 X 

8 Address 

XXXXXXXX1001 1 1 X 



XXXXXXXX1001 1 1 X 


TTTTTTTT100111X 



Scale divisor or 111110 1 

Dividend Subroutine 



XXXXXXXX1001 1 1 X 



XXXXXXXXIOOlO/ilX 


XXXXXXXX1 101 100 



Select next sequential instruction. Load 
abort address into Address register. 



Select next sequential instruction, or abort 
address if Z = 1 from microinstruction 1 . 



Select next sequential instruction. 



OVR = Select next sequential instruction. 
OVR = 1 . Call "scale dividend" subroutine. 



OVR = 0. Select next sequential address. 
OVR = 1. Branch to microinstruction 8. 



Select next sequential instruction. 



Select next sequential instruction. 



C(N+4) = 0. Select next sequential instruction. 
C(N+4) = 1 . Call "scale divisor or dividend" 
subroutine. 

Select next sequential instruction. 



Execute this instruction 1 4 times, then select 
next sequential instruction. 



Return from subroutine. 



X = "Don't Care" bits 
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Status outputs from the 2901 or 2903 devices have already been encountered; we have, for example, discussed the 
way in which the Overflow status may generate one of the OR mask lines. The most effective way of handling status 
outputs from 2901 or 2903 slices is to use the test input of 2981 1 A. This might be illustrated as follows: 




♦ » ♦ i 



13 12 II 10 



29811 A 



TEST 



• COUNTER LOAD 
■ COUNTER ENABLE 



MAP ENABLE 
•PIPELINE ENABLE 
•FE 
-PUP 
>S1 
-SO 



OUTPUT ENABLE 



2909/291 1 ADDRESSING EXAMPLE 

We will now complete our discussion of 2909 and 291 1 operations by looking at a specific example — the twos 
complement binary division microprogram summarized in Table 8-9. Table 8-9 shows only those 
microinstruction bits required by the 2903 device. In Table 8-11 we add microinstruction bits for two 2911 
Microprogram Sequencers. We assume that the two 291 1 Microprogram Sequencers address the 2903 twos comple- 
ment binary division microprogram as a subroutine, within a 256-microinstruction microprogram memory. 

In the lower half of Table 8-1 1 , RAM locations used by the twos complement binary division microprogram are iden- 
tified using register designations "RO" through "R4". These designations represent RAM locations with addresses 
through 4, respectively. 

Additional microinstruction bits added in the lower half of Table 8-1 1 provide the two 291 1 Microprogram Sequen- 
cers with their data and control inputs. Eight data input bits are needed, four for each of the two 291 1 Microprogram 
Sequencers. But since both 291 1 Microprogram Sequencers will receive exactly the s ame control inputs, one set of 
control signals is sufficient. Table 8-1 1 shows the six control signals RE, SI, SO, ZERO, CN, FE, and PUP being gener- 
ated by individual microinstruction bits. But earlier we generated these control codes out of a read-only memory. In the 
discussion which follows we will compare these two methods of generating control inputs. 

Microinstruction 1 in Table 8-1 1 copies the divisor into a temporary register. If the divisor is not 0, the next se- 
quential microinstruction must be executed. If the divisor is 0, microprogram execution must be aborted, since you 
cannot divide by 0. The most significant 2903 slice outputs Z high if the divisor is 0. Z is output low if the divisor is not 
0. The Z status is output at the end of the microinstruction 1 microcycle, too late to influence 291 1 Microprogram Se- 
quencer logic. Microinstruction 1, therefore, provides the 2911 with data needed to evaluate the Z status while 
microinstruction 2 is executing. SO and SI are both low while CN is high; therefore,while microinstruction 1 is execut- 
ing, the 2911 Output Multiplexer selects the Microprogram Counter as its source, then increments the Microprogram 
Counter contents. Thus, the next sequential microinstruction, microinstruction 2, is selected. Simultaneously, 
microinstruction 1 inputs the abort address to the 291 1 Address register. The abort address is input at D0-D7 while RE 
is low. 

If logic associated with execution of microinstruction 2 conflicted in any way with testing the Z status, then we would 
have to insert a dummy microinstruction in front of microinstruction 2, whose sole function would be to test the Z 
status. 



But microinstruction 2 has n o such conflicting logic, so we can use its execution time to test the ZERO status generated 
by microinstruction 1 . If this ZERO status is 1 , then the abort address, input to the Address register by microinstruction 
1, will be selected; execution of microinstruction 2 becomes redundant insofar as 2903 logic events are concerned, 
but, providing execution of microinstruction 2 is inconsequential, no harm is done. 



The 291 1 bits provided by microinstruction 2 can be quite simple. SI is and SO is connected to the ZERO status; if 
the ZERO status is , the O utput Multiplexer will select the Microprogram Counter — and thus the next sequential in- 
struction. But if the ZERO status is 1, the Address register will be selected by the Output Multiplexer — and thus an 
abort will occur. In order to connect SO to a ZERO status we would pro bably include an additional enable bit, not shown 
in microinstruction 2. This enable bit, when high, will link SO to the ZERO status, but when low will cause SO to be 
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derived directly from its microinstruction bit. This may be illustrated as follows: 



SO Bit- 



^O 



ENABLE- 



;=o 



ZERO- 



b^^c^ 



•so 



Addressing logic for microinstructions 3 and 4 is similar to that which we have just described for microinstruc- 
tions 1 and 2. 

Microinstruction 3 converts the most significant half of the dividend from twos complement to sign/magnitude form. If 
the dividend has the largest possible twos complement value, then the Overflow status is set and the dividend must be 
downshifted. If the dividend has any other twos complement value, the Overflow status is not set and the next sequen- 
tial instruction must be executed. But as we found when examining microinstruction 1, the Overflow status is gener- 
ated at the end of the microinstruction 3 microcycle, therefore the 291 1 bits shown in Table 8-1 1 for microinstruction 
3 simply select the next sequential microinstruction — microinstruction 4. But while microinstruction 4 is being ex- 
ecuted, 291 1 logic tests the Overflow status generated by microinstruction 3. Now we can delay testing microinstruc- 
tion 3 Overflow status until microinstruction 4 has been executed because execution of microinstruction 4 does not 
conflict with Overflow = 1. If it did, we would have to insert a dummy microinstruction between 3 and 4 which did 
nothing at the 2903, but gave the 291 1 an additional microcycle time within which to test the Overflow status gener- 
ated by microinstruction 3, and determine subsequent addressing based on Overflow status level. Since this additional 
dummy instruction is not needed, microinstruction 4 provides the address for the "Scale Dividend" subroutine via data 
bits D0-D7. Two sets of control inputs are generated. If the Overflow status left over from microinstruction 3 is then 
the control inputs to the 291 1 simply select the next sequential microinstruction — microinstruction 5. But if the Over- 
flow status left over from microinstruction 3 is 1 then control inputs cause the 2911 to push Microprogram Counter 
contents onto the Stack, then have the Output Multiplexer choose as its source the address input at D0-D7. Thus the 
scale dividend subroutine is called. 

If you look at the 2911 control bits of microinstruction 4 in Table 8-11, you will see that three bits, SO, SI, and FE, 
must change, depending on the level of the Overflow status left over from the execution of microinstruction 3. PUP 
need not change, since i ts leve l is not significant when OVR is low. We could control all three bit levels using an enable 
bit, as described for the ZERO status in microinstruction 2. But it is probably simpler and cheaper to use a read-only 
memory device, as suggested earlier in this chapter. Consider the following possibility: 

Control 
Bits 



D7 D6 D5 D4 D3 D2 D1 DO A4 A3 A2 A1 AO Microinstruction bits for 2911 



ZERO- 

OVR- 

C(N-H4)- 



8-Bit 
ROM 
Address 



Instead of having seven separate 291 1 control bits in every microinstruction, we now have five control bits. Three 
status bits (ZERO, OVR, and C(N-l-4), generated by the 2903) provide the three low-order bits for an 8-bit read-only 
memory address. The five microinstruction control bits, together with the three status bits generated by the 2903, 
create an 8-bit read-only memory address. The addressed read-only memory location outputs the seven signal levels 
required by the 2911. For microinstructions 1 through 4, read-only memory might arbitrarily be mapped as shown in 
Figure 8-35. 

Microinstruction 5 has 2911 addressing bits that are similar to microinstruction 4. Microinstruction 4 not only 
tests the Overflow status left over from microinstruction 3, but itself generates an Overflow status which must be 
tested while microinstruction 5 is being executed. In the event that the 2903 Overflow status generated by 
microinstruction 4 is low, the next sequential microinstruction, microinstruction 6, is selected. But if the Overflow 
status is high, then a branch to microinstruction 8 occurs. Since this is a simple branch, no push is required: therefore 
FE remains high in both cases. See Figure 8-35. 
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Address Bits from 
Microinstruction 



o £» 
ti E 



1 

2 
2 
3 
4 
4 
5 
5 
6 
7 
8 
8 
9 

10 
10 
11 



A4 



A3 



A2 



A1 



AO 



Status from 
2903 




<i •" 



(I ^ 



Sync/Enable 
ROIVI (Map 



9 

A 

B 

C 

D 

E 

F 

10 

11 

12 

13 

14 

15 

16 

17 

18 

19 

1A 

IB 

1C 

ID 

IE 

IF 

20 



27 
28 
29 
2A 
2B 
2C 
2D 
2E 
2F 
30 
31 
32 
33 
34 
35 
36 
37 
38 

3F 



RE 



S1 



1 I 1 



SO 



CN 



FE 



Figure 8-35. 2911 Sync/Enable ROM for the 2903 Twos Complement Binary 
Division Microprogram Subroutine 
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Microinstructions 6 and 7 both have very simple 2911 addressing logic. Each microinstruction chooses the next 
sequential microinstruction. But the Carry status generated by the 2903 following execution of microinstruction 7 must 
be tested by address generation logic while microinstruction 8 is being executed. The fact that microinstruction 5 can 
branch directly to microinstruction 8 causes no problem since microinstruction 5 will always generate a low 2903 Carry 
status; thereforhe Carry status testing logic which we are about to describe does no harm. 

If the Carry status generated by the 2903 during execution of microinstruction 7 is low, then no further divisor or divi- 
dend scaling is needed, and the next sequential microinstruction is selected. But if the 2903 generates a high Carry 
status while executing microinstruction 7, then a subroutine must be called to scale the divisor or dividend. Therefore 
microinstruction 8 provides the address of the scaling subroutine at the data inputs D0-D7; it generates the 
same two sets of 2911 control inputs which we described for microinstruction 4. However, the level of C(N-l-4) 
determines which set of 291 1 control inputs are selected by microinstruction 8. See Figure 8-35. 

We now come to the last three microinstructions (9, 10, and 1 1) which together perform the actual twos com- 
plement binary division. Microinstruction 9 must be executed once, followed by fourteen executions of microinstruc- 
tion 10, and one execution of 11. Fourteen executions of microinstruction 10 are required because we are dividing a 
16-bit divisor into a 32-bit dividend. From our previous discussion of the twos complement binary division algorithm, 
recall that microinstruction 10 must be executed N times, where the divisor has N bits and the dividend has 2N bits. 
Our 291 1 addressing logic implements this multiple execution requirement by keeping the CN input low for thirteen 
executions of microinstruction 10. But this requires an external counter. Here is one possibility: 



A4 

A3 

A2 

A1 

AO 



ZERO- 



> 



ENABLE 



x14 Counter, 
advanced 
by ENABLE 



COUNT 



I>^==1> 



•ZERO 



There are innumerable ways (including the use of a 2910) in which the counting logic required to augment 
microinstruction 10 may be implemented. The one we have shown assigns one set of eight read-only memory ad- 
dresses to a preloaded counter. This preloaded counter provides the level of the low-order address bit (zero) which must 
be input to the 291 1 select ROM. The preloaded counter decrements once every time ENABLE goes high; it outputs 
COUNT low until it decrements to 0. Upon decrementing to the counter outputs COUNT high. 

Apart from the external counter required by microinstruction 10, microinstructions 9 and 10 generate simple next se- 
quential address controls for the 291 1 . Microinstruction 1 1 causes the 291 1 to pop its Stack — on the assumption that 
the entire twos complement binary division microprogram is itself a microprogram subroutine. Thus, if a read-only 
memory is used to generate 291 1 control inputs Figure 8-35 illustrates the final read-only memory map and address- 
ing bits required for the microinstruction sequence given in Table 8-11. 
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THE 2910 MICROPROGRAM SEQUENCER 

This device is an enhancement of the 2909/2911 Microprogram Sequencers which we have just described. 
Here is a summary of 2910 enhancements, as compared to the 2909 and 291 1 : 

1) The 2910 is a 12-bit device capable of addressing up to 4096 microinstructions. The 2909 and 2911 are 4-bit 
devices. Therefore the 2910 is equivalent to three parallel 2909/291 1 devices. 

2) The 2910 has sixteen address generation sequences, selected individually via four instruction code inputs. Many of 
these sixteen address generation sequences have alternate forms that depend on the level of a condition code. The 
2909/2"911 has no such address generation sequences; rather, individual control signal levels (such as output 
selects SO and SI, and output masks OR0-OR3) provide more primitive control of addressing logic. 

3) The 2910 has three enable signals. One of the three is output low on each microcycle. You can use these enable 
signals to selectively strobe data out of different sources to meet the specific needs of any microcycle. The 2909 
and 2911 have no such enable outputs. 

4) The Address register of the 2909/2911 becomes an Address register or a down counter within the 2910. As a 
down counter, the 2910 Address register controls loop iteration. 

5) The 2910 has a five-level Stack, as compared to the 2909/2911 four-level Stack. Also, the 2910 has slightly 
different Stack Pointer logic. 

The fact that the 2910 is an enhancement of the 2909/291 1 does not necessarily mean that the 2910 is always 
the part of choice. The 2910 is more expensive. In most cases, a small microprogram consisting of 256 or fewer 
microinstructions is more economically served by two 2909 or 2911 devices, rather than a single 2910 device. 

The 291 is packaged as a 40-pin DIP or a 42-pin flat package. The device is manufactured using bipolar technology. A 
single +5V power supply is required. Ail signals are TTL-level compatible. 

2910 MICROPROGRAM SEQUENCER PINS AND SIGNALS 

For an overview of Microprogram Sequencer logic, and how it is used within a 2900-based system, refer to our earlier 
discussion of this subject given for the 2909/291 1 devices. The discussion which follows assumes that you understand 
how a Microprogram Sequencer fits into a 2900-based configuration. 

2910prnsandsignalassignmentsare illustrated in Figure 8-35. Figure 8-37 illustrates 2910 functional logic. 
We will describe signals in conjunction with functional logic. 

The Output Multiplexer is central to logic of the 2910 Microprogram Sequencer. An in- 
struction code input via 10-13 determines which of the four possible inputs will be 
selected by the Output Multiplexer. In contrast, the 2909 and 291 1 have two control inputs, 
SO and SI, that determine the source which the Output Multiplexer selects. 



2910 

MICROPROGRAM 

COUNTER 



2910 DATA 
INPUT 



D0-D11 are twelve data input lines whi ch, li ke the 2911, can input data to the Address 

register, or to the Output Multiplexer. If RLD is low, then data input at D0-D1 1 is loaded 

into the Address register on the low-to-high transition of clock signal CP. Data input via DO- 

D1 1 is selected by the Output Multiplexer when an appropriate instruction is input via 10-13. Timing for an Address 

register access may be illustrated as follows: 



D0-D11 




The 2910 outputs the microprogram address via Y0-Y11. These address output lines have 
their own enable signal OE. If this signal is high, Y0-Y1 1 outputs are floated. This allows you to 
disconnect Microprogram Sequencer devices from the microprogram ROM, something you will 
likely do when switching to a test program. 
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2910 

ADDRESS 

OUTPUT 




Pin Name 


Description 


Type 


DO - D11 


Combined Address register and data input 


Input 


YO - Y1 1 


Address output 


Output, Tristate 


VECT 


Vector address enable 


Output 


MAP 


Map address enable 


Output 


PL 


Pipeline address enable 


Output 


RLD 


Address register Input enable 


Input 


OE 


Output enable 


Input 


CI 


Carry in 


Input 


10-13 


Instruction code 


Input 


CC 


Condition code 


Input 


GCEN 


Condition code enable 


Input 


FULL 


Stack full error indicator 


Output 


CP 


System clock 


Input 


Vcc- GND 


Power, Ground 






Figure 8-36. 2910 Microprogram Sequencer Pins and Signal Assignments 
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Figure 8-37. 2910 Microprogram Sequencer Functional Logic 
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Note that the 2910 has no zero input control on the address output lines, nor does it have any OR mask inputs. The 
2909 and 291 1 have such logic on the address output path. Instead, the 2910 uses its instruction codes to generate 
equivalent addressing logic. 

Like the 2909 and the 291 1, the 2910 has two internal locations within which addresses can be held. These are 
the Microprogram Counter and the Stack. 

The 2910 Microprogram Counter logic is functionally identical to that of the 2909/2911 
Microprogram Counter. Any address output by the output multiplexer also passes through 
the incrementer, and is then stored in the Microprogram Counter. If CI is input high, then 
the address output by the multiplexer is incremented by 1 before being written to the 
Microprogram Counter. If CI is input low, then the address is written into the Microprogram 
Counter without being incremented. 



2910 

MICROPROGRAM 

COUNTER 



2910 
INCREMENT 



The 2910 incrementer generates no Carry Out. Thus if you connect two 29 10 Microprogram Sequencers in parallel, you 
cannot increment the resultant 24-bit Microprogram Counter contents across the low- and high-order halves of the ad- 
dress. But, given current microprogramming technology, this is unlikely to pose any problem. Few single 
microprograms have more than 4096 microinstructions, and you can use multiple 2910 Microprogram Sequencers to 
address large microprograms in discrete 4096-microinstruction blocks. 



The 2910 Microprogram Sequencer has a five-level Stack. The Stack is addressed by a Stack 2910 

Pointer which initially addresses Stack Register 0. Appropriate instruction codes, input via 10-13, STACK 

generate Stack pushes or pops. A Stack push writes the Microprogram Counter contents to the 
currently selected Stack location and then increments the Stack Pointer. The Stack Pointer always points to the last 
word written. A Stack pop decrements the Stack Pointer. You must select the Stack as the output multiplexer source in 
order to load the current top-of-stack plus one via the incrementer into the Microprogram Counter. 

If you execute more than five pushes, the Stack Pointer continues to address the last Stack location (number 4); the 
Microprogram Counter contents are written into this location, overwriting prior data. This will inevitably cause an error 
The 2910 Stack Pointer does not wrap around, and will not increment from 4 to 0. Stack full is indicated by the FULL 
signal. When either four words have been pushed and a fifth push is selected via 10-13 or five words have been pushed, 
FULL goes low. Thus it can be tested to see if the Stack is full. 

If you try to pop the Stack when the Stack Pointer is addressing location 0, then the Stack Pointer continues to select 
location 0. Since no data is written into the Stack following a pop, no prior information will be destroyed; however, in 
all probability you have a microprogramming error. No error signal is output at this time. 

The various addressing operations which the 2910 Microp rogram Sequencer can perform 
are identified using an instruction code input at 10-13. CCEN (condition code enable) and CC 
(condition code) are two additional control inputs that in some cases modify the addressing 
operations wh ich th e 2910 Microprogram Sequencer will perform. T hese s ix 2910 signals — 
10-13, CC, and CCEN — together replace the 2909/291 1 signals SO, SI, ZERO, OR0-OR3, FE, and PUP 

2910 responses to 10-13 inputs are summarized i n Tabl e 8-12. As shown in this table, many 
of the responses depend o n the l evel of the CC and CCEN inputs. Vendor literature describes CC 
as a "condition code" and CCEN as an enable; however, in effect, CCEN must be low while CC 



2910 

INSTRUCTION 

CODES 



2910 

CONDITION 

CODES 



is high to select a "fail" condition, while any other combination of CC and CCEN in put le vels 

select a "pass" condition. Your design logic can use CC as a pass/fail selector, with CCEN as an override. This logic 

may be illustrated as follows: 



CC- 



O 



Condition Code 
CCEN- 

In response to each instruction code input at 10-13, 29K) l ogic per forms operations which we will describe individually. 
Also, 2910 logic outputs low one of the three signals PL, MAP, or VECT. You can use these three signals as you see fit, 
however their intend ed p urpos e is to enable one of three possible inputs to D0-D11. Figure 8-38 functionally illus- 
trates timing for PL, MAP, and VECT as part of the 2910 microcycle response. 



VECT low will normally select a restart interrupt or other special address. 

MAP will normally enable the mapping ROM out of which a microprogram starting address is generated in response to 
a macroinstruction op-code. 



VECT and MAP are the exceptional enable outputs. PL is the enable signal which is usually output low. This signal will 
likely enable the Microinstruction register, or a connected Data register, allowing the microinstructi on to determ ine the 
next data input to appear at D0-D1 1 . With reference to Figure 8-31 , Figure 8-39 identifies how VECT, MAP and PL 
will likely be used. 
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Figure 


B-38. 2910 Microcycle Event Sequences 









2910 MICROPROGRAM SEQUENCER INSTRUCTIONS 

We will now examine 2910 Microprogram Sequencer instructions in detail. First, we will describe each instruc- 
tion individually, then we will look at the instructions functionally, showing when instructions are likely to be 
used, and in what combinations. 

Instruction (JZ) is a Jump-to-Zero instruction. This instruction forces the address to be output at Y0-Y11; 
therefore the Microprogrann Counter will subsequently hold the address or 1 , depending on the level of the CI input. 
The JZ instruction also resets the Stack Pointer to 0, effectively clearing the Stack. Since this instruction restarts execu- 
tion with the microinstruction stored at nriicroprogram nnemory location 0, JZ is frequently used as a power-up, reset, or 
Restart instruction code. 

Instruction 1 (CJS) is a Conditional Jump-to-Subroutine instruction. A "pass" condition pushes the current 
Microprogram Counter contents onto the Stack and takes the next microinstruction address from the D0-D1 1 inputs. A 
"fail" condition causes the next sequential microinstruction to be executed. This may be illustrated as follows: 

M-*- Address "M" must be input 
at DO - D1 1 . Address "N+ 1 " 
is saved on the Stack. 

'fail" " 




8-114 



Restart 
Address 
Register 



\> 



nOE 



Macroinstruction 



Q. 



Macroinstruction 
Register 



iz 



Mapping 
PROM/ROM 






OE 



VECT 



PL 



iz 



2910 

Microprogram 

Sequencer 



MAP 



2910 Control Inputs 



\> 



Microprogram 
PROM/ROM 



OE 



2910 data 
to DO - D1 1 



n 



Microinstruction 
I Register 



V 



To 2901 or 2903 slices 



Figure 8-39. 2910 Enable Signal Utilization 



8-115 



Table 8-12. 2910 Microprogram Sequencer Instruction Codes Sunnnnary 



Instruction 










Address 




Code 


Vendor 
Mnemonic 


Y 
Output 


Enable 
Output 


Stack 
Operation 


Register/ 
Counter 


Comment 


£ 


13 12 11 10 u 










Operation 




X 


JZ 





PL 


SP = 





Reset or restart 


10 


CJS 


DO - D11 


PL 


PUSH 


— 


} Jump to subroutine If CC Is "pass" 
) Continue otherwise 


1 1 


[PC] 


PL 


— 


— 


1 X 


JMAP 


DO - D1 1 


MAP 


— 


— 


Start new microprogram 


110 


CJP 


DO - D11 


PL 


— 


— 


) Jump If CC Is "pass" 
J Continue otherwise 


111 


[PC] 


PL 


— 


— 


10 


\ PUSH 


[PC] 


PL 


PUSH 


D0-D11 


Push Stack and load Address register 


10 1 


[PC] 


PL 


PUSH 


— 


Push Stack 


10 10 
10 1 1 


[ JSRP 


DO -D11 
[AR] 


PL 
PL 


PUSH 
PUSH 


— 


y Jump- to-Subroutlne 


110 


CJV 


DO - D1 1 


VECT 


— 


— 


) Accept vector address If CC Is "pass" 
f Continue otherwise 


110 1 


[PC] 


VECT 


— 


— 


1110 
1111 


j- JRP 


DO -D11 
[AR] 


PL 
PL 


I 


— 


Jump 


1 X 


RFCT 


[S] 


PL 


— 


DEC 


Counter not } Repeat subroutine until 
Counter ) Counter Is 






[PC] 


PL 


POP 


— 


1 1 X 


RPCT 


DO - D1 1 


PL 


— 


DEC 


Counter not 1 Repeat loop until 
Counter ) Counter is 0_ 






[PC] 


PL 


— 


— 


10 10 


CRTN 


[S] 


PL 


POP 


— 


I Return from subroutine if CC Is "pass" 
I Continue otherwise 


10 10 1 


[PC] 


PL 


— 


— 


10 110 


i CJPP 


DO -D11 


PL 


POP 


— 


) Jump and return if CC Is "pass" 
} Continue otherwise 


10 111 


[PC] 


PL 


— 


— 


1 1 X 


LDCT 


[PC] 


PL 


— 


D0-bl1 


Load Address register/Counter 


110 10 


[ LOOP 


[PC] 


PL 


POP 


— 


{ End loop if CC is "pass" 
} Continue otherwise 


110 11 


[S] 


PL 


— 


— 


1 1 1 X 


CONT 


[PC] 


PL 


— 


— 


Continue with normal sequence 


11110 


) 


[PC] 


PL 


POP 


DEC 


Counter not Hf CC Is "pass" 
Counter J decrement Counter to 




> TWB 


[PC] 


PL 


POP 


— 


11111 


) 


[S] 


PL 


— 


DEC 


Counter not ) Otherwise decrement Counter 
Counter ) to and branch 






DO - D1 1 


PL 


POP 


— 


'^'o represents CC is "pass" condition. CCEN 










= 1, or CCEN 


= and CC = 


0. 




1 represents CC "fail" condition. CCEN = 


and CC = 1 . 








DO - 01 1 = data input at DO - D1 1 . 










[PC] = contents of Microprogram Counter. 










[AR] = contents of Address register/Down Cou 


nter. 








[SI = contents of Stack register currently addre 


ssed by the S 


tack Pointer. 






SP = means the Stack Pointer is reset to 0. 










PUSH means write [PC] to [S] then increment 


Stack Pointer. 








POP means decrement Stack Pointer. 










DEC means decrement [AR]. 











Instr uction 2 (JMAP) is a Jump Map instruction. This instruction outputs the address input at D0-D1 1 , together with 
a low MAP enable. The Microprogrann Counter subsequently holds the address which was input at D0-D1 1, or this ad- 
dress incremented by 1, depending on the CI input. JMAP is usually the first code input to a 2910 Microprogram Se- 
quencer at the start of a new macroinstruction's execution. That is to say, the last microinstruction implementing the 
Cen tral P rocessing Unit's instruction fetch sequence will transmit a JMAP code to the 2910 Microprogram Sequencer 
The MAP output will enable the mapping ROM which receives as its address input the macroinstruction op-code, and 
generates as its output the address for the first microinstruction to be executed in response to the macroinstruction 
(see Figure 8-40). We described this sequence in detail when discussing the 2909 and 2911 Microprogram Se- 
quencer. We can illustrate the JMAP instruction code as follows: 



1 



M-^ Address "M" must be input 
at D0-D11 
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Instruction code 3 (CJP) is a Conditional Jump Pipeline instruction. If the condition code "passes", then D0-D1 1 
provides the next address output via Y. 

If the condition code "fails", then the next sequential instruction is executed. The address input to D0-D1 1 will come 
from the external location enabled by PL. As illustrated in Figure 8-40, this will probably be the Microinstruction 
register. This may be illustrated as follows: 



'■''-'■■ <-^ulVr 



pass 



1 i 



M-*-Address "M" must be input 
at DO - D1 1 



Instruction code 4 (PUSH) is a Stack Push instruction which also loads the Address register if the condition code 
passes. There are many ways in which you can use this instruction. At its most elementary level, it is a Subroutine Call 
(represented by the push) with an optional simultaneous data load into the Address register. The data loaded into the 
Address register will probably come from the microinstruction itself, since PL is output low by the push. 

Instruction code 5 is a Conditional Jump-to-Subroutine (JSRP). This instruction code pushes the Microprogram 
Counter contents onto the Stack, and calls one of two subroutines, depending on the condition code. If the condition 
code "passes", then the subroutine starting address is provided immediately at the D0-D11 inputs. If the condition 
code "fails", then the subroutine starting address is taken from the Address register. This may be illustrated as follows: 




Address "M" must be 
input at DO - D1 1 . 
The return address 
"N+1" is pushed 
onto the Stack 



Address "P" must 

have been loaded 

previously into 

the Address 

register. The 

return address 

"N+1" is pushed 

onto the Stack 

Instruction code 6 is a Con dition al Jump Vector (CJV). It is significant principally because it is the only instruction 
code which generates a low VECT output. This low output usually enables a special Address register, out of which a 
direct memory access or interrupt address is fetched. 

If CC is in the "pass" condition, then the output multiplexer takes as its source D0-D1 1. If CC is in the "fail" condition, 
the next sequential instruction is executed. 

Instruction code 7 is a Conditional Jump (JRP) which differs from the Conditional Jump-to-Subroutine (instruction 
code 5) only in that no push occurs. If the condition code "passes", then the microinstruction execution sequence 
jumps to the address which is input at D0-D1 1 ; otherwise, the microinstruction sequence jumps to the address held in 
the Address register. This may be illustrated as follows: 



Address "P" must P . 

have been loaded I 

previously into I 

the Address register. ¥ 



"fail" V "pass" 



— I M Address "M" must 

be input at DO -D11. 



Instruction code 8 is a Repeat-Loop-Until-Counter-ls-Zero (RFCT) instruction. The purpose of this instruction code 
is to re-execute one or more microinstructions some fixed number of times. The microinstruction loop to be re-executed 
has its starting address stored in the Stack. The loop count is handled by the Address register, which must be 
preloaded with a number that is one less than the required count. For example, if the Address register is loaded with an 
initial value of 8, then the microinstruction loop will be executed 9 times. Thus, you can load into the Address register 
values ranging between and 4095 to generate counts ranging between 1 and 4096. 
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When the 2910 receives an RFCT instruction code, it exannines the Address register contents. If the Address register 
does not contain 0, then the output multiplexer takes as its source the currently addressed Stack location; the Address 
register contents are then decremented. If the Address register contents are 0, then the output multiplexer selects the 
Microprogram Counter as its source; also the Stack is popped. 

We can illustrate the RFCT instruction code as follows: 



Address register 
contains 0. 
Pop Stack. 






Address "M" must 
have been pushed 
onto the Stack. 



Address register does 
not contain 0. Decrement 
Address register. 



Now the RFCT instruction, as illustrated above, re-executes a loop if the branch address M precedes N, where N is the 
microprogram location. But you can push any address onto the Stack prior to executing an RFCT code. For example. 
RFCT could be used to branch some fixed number of times without re-executing a loop. This may be illustrated as 
follows: 



Address register 
contains 0. 
Pop Stack. 



.1 



I Address register 
does not contain I 
0. Decrement y 
Address register 
and branch to "M". 



Address "M" must 
have been pushed 
onto the Stack. 



Instruction code 9, the Repeat-Register-Until-Counter-ls-Zero (RPCT) instruction, is almost identical to instruc- 
tion code 8. RPCT again uses the Address register as a counter. If when RPCT is executed the Address register does not 
contain 0, then it is decremented and the output multiplexer chooses as its source an immediate address input at DO- 
D1 1 . If the Address register contents are 0, then the output multiplexer selects as its source the Microprogram Counter. 
The Stack is not used. 

If the microinstruction which generates the RPCT code supplies its own address at D0-D1 1, then this microinstruction 
gets re-executed the number of times specified by the Address register contents. This may be illustrated as follows: 



Address register 
contains 6. 
Pop Stack. 



-•*-N+1 »-N+1 



Address "N+r 
be input at DO 

Address register does 
not contain 0. Decrement 
Address register. 



must 
D11. 



But a microinstruction does not have to supply its own address at D0-D1 1 when specifying the RPCT instruction code. 
It can input any address at D0-D1 1. Thus, RPCT can be used to re-execute an instruction loop, or RPCT can be used to 
execute any other branch some fixed number of times, as illustrated for the RFCT instruction code. 

Instruction code A is a Conditional Return-from-Subroutine (CRTN). If the condition code "passes", then a Return- 
from-Subroutine occurs. The output multiplexer takes the currently addressed Stack register as its source, then pops 
the Stack. If the condition code "fails", then the next microinstruction address is taken from the Microprogram Counter. 
This may be illustrated as follows: 



N+1" must be the address 

currently in the top of 

the Stack. 




":',:-■' ■■"'■ 



8-118 



Instruction code B is a Conditional Jump-and-Return instruction (CJPP). If the condition code "passes ", then the 
Stack is popped, but the output multiplexer takes D0-D1 1 as its source. This is equivalent to a subroutine return where 
the return address is not taken from the Stack, even though the Stack is popped; rather, the return address is taken 
from D0-D1 1. if the condition code "fails", then normal sequential microinstruction execution occurs with the next 
microinstruction address being taken from the Microprogram Counter. 

Instruction code C is a Load Counter instruction (LDCC). When this instruction code is executed, microprogram ex- 
ecution continues sequentially, with the output multiplexer taking the Microprogram Counter as its source; however, 
data input at D0-D1 1 is loaded into the Address register. 

Instruction code D is a Conditional End-of-Loop (LOOP). As long as the condition code "fails", the output multiplex- 
er selects the currently addressed Stack register as its source. When the condition code "passes", the Microprogram 
Counter is selected as the output multiplexer source and the Stack is popped. This may be illustrated as follows; 



pass c 



M 



N 



r 



"fail" 



Address "M" must 
have been pushed 
onto the Stack. 



The LOOP instruction code is equivalent to the RFCT instruction code, with the condition code, rather than the Address 
register, determining the number of loop iterations. 

The LOOP instruction code does not have to be used to re-execute a loop. In the illustration above a loop is re-executed 
only because the address M is shown preceding N, the microinstruction address where the loop code is generated. If 
the address M does not precede N, then the LOOP instruction code becomes a simple conditional jump, where the 
jump address is held at the top of the Stack. 

Instruction code E is a Continue instruction (CONT). This is the normal default instruction code. It causes the next 
sequential microinstruction to be addressed. The output multiplexer selects the Microprogram Counter as its source. 
No other operations occur. 

Instruction code F is a three-way branch (TWB); it uses the condition code and the Address register. Whether the 
condition code "passes" or "fails", the Address register contents are decremented to 0. If the condition code "passes", 
then the Stack is popped and the Microprogram Counter is selected as the output multiplexer source. If the condition 
code "fails", then the Stack is selected by the output multiplexer while the Address register is decrementing, but when 
the Address register has decremented to 0, the Stack is popped and the output multiplexer selects as its source data in- 
put at D0-D1 1. These options may be illustrated as follows; 



On "pass" decrement 

Address register to 

"pass" 0, then pop 

Stack. 




Address register does not contain 0. 
Decrement address register. 
Address "M" must have been 
pushed onto the Stack. 



Address register contains 0. 
Address "P" must be 
input at DO - D11. 



The TWB instruction code is, in effect, a conditional loop execute. While the condition code is failing, the microinstruc- 
tion sequence between M and N is re-executed a number of times, as defined by the Address register; microprogram 
execution then branches to an address input at D0-D1 1. But any single loop iteration can be bypassed by a "pass" con- 
dition code; moreover, when the Address register has decremented to 0, microprogram execution can continue se- 
quentially, or it can branch to the address input at D0-D1 1. 



8-119 



2910 MICROPROGRAM SEQUENCER ADDRESSING SEQUENCES 

Let us now examine some of the more common microprogram address sequences which you are iiicefy to en- 
counter, and how these address sequences will be generated using a 2910 Microprogram Sequencer. 

A simple sequence of consecutive microinstructions represents the simplest case: 



Address 


2910 Instruction 


Sequence 


Code Sequence 


N 


CONT 


N+1 


CONT 


N+2 


CONT 


N+3 


CONT 


etc 


etc 



2910 

MICROPROGRAM 

INITIALIZATION 



2910 

MICROPROGRAM 

JUMP 



You generate sequential microinstruction addresses, as required by the sequence above, using instruction code E, with 
the CI input high. 

You will likely initialize your microprogram in one of two ways: 

1) Following a restart or special condition, use instruction code (JZ); this forces a output 
at Y. or 1 can be written to the Microprogrann Counter — depending on the level of the 
CI input. 

2) At the end of an instruction fetch, use instruction code 2 (JMAP) to take the microprogrann starting address from a 
mapping ROM. We described this instruction code earlier. 

The 2910 Microprogram Sequencer gives you many ways of jumping within a 
microprogram. Any instruction code that causes the output multiplexer to select D0-D1 1 or the 
Address register as its source can be used to generate a microprogram jump. Instruction code 3 
(CJP) jumps to the address input at D0-D1 1 if the co ndition code pa sses. S o does instruction code 
6 (CJV), but instruction code 6 (CJV) outputs VECT low — and the VECT enable signal is commonly used to select a 
special DMA or interrupt address. Instruction code 7 (JRP) is a dual, unconditional jump; if the condition code 
"passes", the jump address is taken from D0-D1 1 , while the jump address is taken from the Address register if the con- 
dition code "fails". 

A microprogram subroutine is called using instruction code 5 (JSRP). This instruction code 
pushes the Microprogram Counter contents onto the Stack; the subroutine starting address is 
taken from D0-D1 1 if the condition code "passes", and from the Address register if the condition 
code "fails". The Address register must have been preloaded with an appropriate starting address 
if the condition code "fails". Generally, instruction code C (LDCT) is used to load the Address 
register. 

A normal Return-from-Subroutine will use instruction code A (CRTN) with the condition code held "passing". 

There are two types of loop you may encounter in a microprogram. You may wish to re-execute a single 
microinstruction, or a sequence of microinstructions some number of times. 

The simplest way of re-executing a single microinstruction some fixed number of times is to load the Address register 
with a number one less than the required count, then issue instruction code 9 (RPCT). This may be illustrated as 
follows: 

Address 2910 Instruction 

Sequence Code Sequence 

N LDCT with M-1 to D0-D1 1 

N-l-1 (M times) RPCT with N-f-l to D0-D11 
N-l-2 CONT 

You can alternatively use instruction code 8 (RFCT) to re-execute a single microinstruction, but the microinstruction 
address must be preloaded onto the Stack. 



2910 

MICROPROGRAM 
JUMP-TO- 
SUBROUTINE 
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More frequently, instruction code 8 (RFCT) will be used at the end of a multi-microinstruction loop. This may be illus- 
trated as follows: 



passing 







Address 
Sequence 


2910 Instruction 
Code Sequence 






N 

-N+1 
N+2 

N+M 
-N+M+1 
N+M+2 


PUSH with P-1 to D0-D11 and CC 

CONT 

CONT 

CONT 
RFCT 
CONT 


Re-execute 

loop N+1 

to N+M+1 

P times 









As illustrated above, the microinstruction preceding the loop must input instruction code 4 (PUSH) with the condition 
code passing. This simultaneously loads the count into the Address register while pushing the next sequential address 
onto the Stack. Subsequently instruction code 8 (RFCT) decrements the Address register, selecting the address which 
PUSH saved on the Stack, until the Address register has decremented to 0. 

2910 ADDRESSING EXAMPLE 

As we did for the 291 1 Microprogram Sequencer, we will now look again at the twos complement binary divi- 
sion microprogram given in Table 8-9, adding address generation microinstruction bits needed by the 2910 
Microprogram Sequencer. See Table 8-13. 

We are going to treat the twos complement binary division microprogram as a subroutine. We assume, therefore, that 
microinstruction 1 is executed following a Jump-to-Subroutine instruction code input to the 2910 Microprogram Se- 
quencer. 

Microinstruction 1 inputs a CONT instruction code to 10-13 of the 2910 Microprogram Sequencer. This causes the 
next sequential microinstruction to be executed. Since the 2910 does not sample its D0-D1 1 inpu ts, t hese b its are ir- 
relevant. CI is input high since the 2910 Microprogram Counter contents must increment. RLD and CCEN are high 
since no data is to be written into the Address register, and the condition code is not used. 

Although microinstruction 1 itself transmits the simplest possible addressing logic to the 291 0, the ZERO status output 
by the 2903 while microinstruction 1 is executed contributes to microinstruction 2 address generation logic. The bin- 
ary division subroutine must be aborted if the divisor is 0. This abort condition is indicated by a ZERO status output 
following execution of microinstruction 1. This ZERO status is output too late during microinstruction 1's microcycle to 
be considered by 2910 addressing logic during execution of microinstruction 1. Therefore, in the event that the 
subroutine must be aborted, microinstruction 2 gets executed gratuitously, but causes an abort exit from the 
subroutine after its gratuitous execution. The CJP instruction code is input to the 2910 Microprogram Sequencer 
by microinstruction 2 in order to achieve this end. This instruction code causes the next sequential microinstruction 
to be addressed if the condition code "fails", while the addressing input at D0-D1 1 is selected if the condition code 
"passes". The address of the micro instru ction to be selected following an abort is therefore input via bits D0-D11. In 
order to enable the condition code, CCEN is low. CC must be connected to the complement of Z while microinstruction 
2 is being executed. This allows the ZERO status output by the execution of microinstruction 1 to generate the CC in- 
put during microinstruction 2 — and thus generate an abort, if needed. We do not show the logic which causes CC to 
be connected to the complement of the 2903 Z status. There are many ways in which such "one time" connections can 
be made. Possibly the simplest technique is to add microinstruction bits which enable a specific NOR gate linking the 
2910 CC input with the 2903 Z output. This may be illustrated as follows: 



CC - Z connect enable 



CC- 



y 



.£ 
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Table 8-13. The 2903 Twos Complement Binary Division Microprogram Subroutine from Table 8-9, 
with 2910 Addressing Microinstruction Fields Added 



No 


Microinstruction 


EA 


CN 


AO- A3 


B0-B3 


Comment 


18 -15 


14- 11 


10 


1 


4 


6 











Divisor register 
(RO) 


Divisor buffer 
(R3) 


Copy divisor to temporary buffer. 


2 


4 


6 











Dividend IMS) 
register (R1) 


Dividend (MS) 
buffer (R2) 


Copy dividend most significant half to temporary buffer. 


3 


5 








X 





X 


Dividend (MS) 
buffer (R2) 


Convert dividend (MS) from twos complement to sign/magnitude version. 
Test OVR externally while next microinstruction is being executed. If OVR is 1 , 
branch to subroutine that downshifts dividend. 


4 


5 








X 





X 


Divisor buffer 
(R3) 


Convert divisor (MS) from twos complement to sign/magnitude version. 
Test OVR externally. If OVR is 1, branch to microinstruction 9. 


5 


9 


4 





X 





X 


Dividend (MS) 
buffer (R2) 


Shift out sign bit of dividend (MS) half in temporary buffer. 


6 


9 


4 





X 





X 


Divisor buffer 
(R3) 


Shift out sign bit of divisor in temporary buffer. 


7 


F 


2 








1 


Dividend (MS) 
buffer (R2) 


Divisor buffer 
(R3) 


Subtract sign bit stripped divisor from sign bit stripped dividend (MS) half. 
If Carry = 1 (dividend larger) branch to subroutine that downshifts dividend 
or upshifts divisor. 


8 


6 


6 











Dividend ILS) 
register (R4) 


X 


Copy dividend least significant half to Q register. 


9 


A* 














Divisor register 
(RO) 


Dividend (MS) 
register (RD 


Double length normalize dividend in MS register and Q register. 


10 


C* 











z 


Divisor register 
(RO) 


Dividend (MS) 
register (RD 


Execute twos complement divide instruction fourteen times. 


11 


E 











z 


Divisor register 
(RO) 


Dividend (MS) 
register (Rl) 


Twos complement divide final instruction. 


•ON 


is connec 


ted to Z 


status 


while tt 


lese tw 


special functions 


are being execute 


d. 
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Table 8-13. The 2903 Twos Complement Binary Division Microprogram Subroutine from Table 8-9, 
with 2910 Addressing Microinstruction Fields Added (Continued) 



n 



18 17 16 16 14 13 12 II 10 EA CN A3A2A1 AOB3B2B1 BO 



13 12 11 lODIIDIODa D8 D7 D6 D5 04 03 02 D1 00 



P IS 

|u CI Ik 



2910 AddrassliHI Op«ratiant 



010001100 0000000011 

6 RO R3 

010001100 00 001 001 

6 Rl R2 





Address for abort 
lllOXXXXXXXXXXXX 
E = CONT 



Scale dividend subroutine 

1 1 B B B B BS B B B B B B, 

3 = CJP ^''^ 

Microinstruction 8 address 

lllOXXXXXXXXXXXX 

E = CONT 



1111001000 100100011 
F 2 1 R2 R3 

011001100000100XXXX 
6 6 R4 

101000000 000000 1 
A RO Rl 

110000000 OX 00000001 
C RO Rl 

111000000 OX 00000001 
RO Rl 




Select next sequential instruction. 



CC is generated by 2903 Z status (Cc = Z). Select next 
sequential microinstruction unless RO from microinstruction 
1 is 0. . Then abort. 

Select next sequential instruction. 



CC is genereted by OVR status. (CC = OVRI. 

Select next sequential instruction unless 

OVR = 1 . Then call "scale dividend" subroutine. 

CC is generated by OVR status. ICC = OVRK 
Select next sequential instruction unless OVR = 1 . 
Then branch to microinstruction 8. 

Select next sequential instruction. 



Select next sequential instruction. 



CC Is generated by C(N+4I. (CC = C(N+4I). 

Select next sequential instruction unless 

C(N+4) = 1 . Then call "scale divisor or dividend" subroutine. 

Load count into address register, push 
next sequential instruction address onto 
Stack and select next sequential instruction. 



Return from subroutine. 



X = "Don't Care" bits 



While it may appear wasteful to dedicate a single microinstruction bit to enabling such a connection, perhaps only 
once in an entire microprogram, in fact the economics of microprogramming often favor wasting a single bit in this 
way. The alternative is to have additional logic which generates a particular input, from one of a variety of outputs, de- 
pending on complex combinations of circumstances. To evaluate this reasoning look at Table 8-13,_where CC may be 
connected at different times to a Zero, Overflow or C(N-l-4) status. You cannot guarantee that the CC generation logic 
will be a known function of any bit field within the microinstruction, since the same bit field may recur somewhere else 
in the microprogram without having the same CC logic requirements. Your only alternative to dedicating a 
microinstruction bit to each CC generation possibility would be to decode the microinstruction address itself; and that 
would not be simple. 

Microinstruction 3 is another example of a microinstruction that generates a status output which contributes to 

subsequent addressing logic — but not until the next microinstruction. Microinstruction 3 itself provides the 2910 
with a CONT instruction code, which together with a high CI c ause s the n ext sequential microinstruction address to be 
output by the 2910. The data bits D0-D1 1 are not used; RLD and CCEN are both high (i.e., in the "off" state). At the 
2903, microinstruction 3 performs a twos complement to sign/magnitude conversion on the contents of RAM location 
R2. If this operation generates a high Overflow status, then R2, which contains the high-order half of the dividend, must 
be scaled by shifting down one bit position. The subroutine should be called, if needed, after microinstruction 3 has 
been executed, and before microinstruction 4 is executed. But microinstruction 3 outputs OVR too late in its microcycle 
for this status to contribute to the next microinstruction address. Therefore microinstruction 4 provides the 2910 with 
addressing logic that tests the OVR status from microinstruction 3's execution. CJS, the Conditional Jump-to- 
Subroutine, is specified by inp utting 1 as the 2910 instruction code. The address of microinstruction 1's subroutine is 
held in data field bits D0-D11. CCEM is output low so that CC can be tested. CC must be connected to the complement 
of the 2903 OVR status output. If CC is low — and OVR is high — then the subroutine addressed by D0-D11 will be 
called. Otherwise, since CI is h igh, the 2910 will output the next sequential microinstruction address — which is the 
address of microinstruction 5. RLD is output high since the address at D0-D1 1 must not be written into the Address 
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register. As we did in instruction 2, again in microinstruction 4 an additional nnicroinstruction bit will likely connect CC- 
to-OVR via NOR gates. And once again we will choose to waste this CC-to-OVR connector bit for the vast nnajorlty of 
microinstructions where such a connection does not apply. 

While microinstruction 4 provides the 2910 with addressing inputs that test the Overflow status generated by 
microinstruction 3, the Overflow status itself is modified by the 2903 while microinstruction 4 is being ex- 
ecuted. This presents no timing problems, since the 2910 has stopped sampling itsCC input by the time microinstruc- 
tion 4 modifies the Overflow status. See Figure 8-38. 

Microinstruction 5 must provide the 291 with addressing inputs that account for the Overflow status gener- 
ated by microinstruction 4, just as microinstruction 4 had to provide the 2910 with addressing inputs that took into 
account the Overflow status generated by microinstruction 3. Microinstruction 5 causes the 2910 to execute a condi- 
tional jump, rather than a conditional subroutine call, since a high Overflow status generated by the 2903 while execut- 
ing microinstruction 4 requires microinstructions 5, 6, and 7 to be bypassed. We do not bypass microinstruction 5, 
since it is during this microinstruction's execution that the 2910 will test the Overflow status from microinstruction 
4 — and determine if a jump is required. This would present a problem if execution of microinstruction 5 upset the 
2903 logic sequence: but it does not. If executed unnecessarily no harm is done. But remember, there may be circum- 
stances under which you may have to insert a dummy microinstruction that generates no operation at a 2903, but 
gives the 2910 time to test 2903 status from the previous microinstruction. 

In our present example micro instru ction 5 inputs a CJP instruction code at 10-13 ofjhe 2910 and the address of 
microinstruction 8 at D0-D1 1. CCEN is low so that 2910 condition code lo gic w ill sample CC, which remains connected 
to the 2903 OVR status, as it was during execution of microinstruction 4. RLD is high so that the address input at DO- 
D11 does not get written into the Address register. CI is high since the next sequential microinstruction must be 
selected if OVR is low — and the condition code test "fails". 

If the condition code test "fails" at the 2910 during execution of microinstruction 5, then microinstructions 6 and 7 
are next executed seque ntial ly. Ea ch of these microinstructions provides the 291 with a simple CONT input at 10-13, 
no data inputs, and CCEN and RLD disabled with CI high, so that the Microprogram Counter will increment. 

Microinstruction 7 subtracts modified versions of the divisor from the dividend. If the Carry Out generated by the 2903 
at C(N-l-4) is 1, then the divisor must be upshifted (or the dividend must be downshifted) in order to guarantee that the 
divisor ultimately has the larger absolute value. C(N-i-4) is generated by the 2903 at the end of the microinstruction 7 
microcycle — too late for the 2910 to take this status output into account until the next microcycle, during which 
microinstruction 8 is executed. In Table 8-13 we show microinstruction 8 providing a Conditional-Jump-to- 
Subroutine input to 10-13, with a subroutine address input to D0-D11. This 2910 addressing logic is identical to 
that which we have already described for microinstruction 4, except that the condition code CC will now be connected 
to the 2903 C(N-l-4) output — again via a special enabling microinstruction bit. The fact that microinstruction 5 might 
have caused the 2910 to generate a branch to microinstruction 8 is not a problem, since C(N-(-4) will be low following 
execution of microinstruction 5: therefore if microinstruction 8 is executed next, the condition code must fail. 

Microinstruction 9 is executed after microinstruction 8 — possibly with a scaling subroutine executed in between. 
Microinstruction 9 prepares the 2910 for execution of microinstruction 10. A PUSH instruction code is input at 10- 
14, with a count input at D0-D11. RLD is low so that the count gets written into the Address register. The 2910 then 
outputs the address of microinstruction 10 since CI is high — so the Microprogram Counter gets incremented 

Microinstruction 10 outputs an RFCT instruction code to the 2910 via 10-13. This instruction code causes the 2910 
to output the address held at the top of the Stack until the Address register decrements to zero The push performed by 
the 2910 while microinstruction 9 was executing loaded microinstruction 10's address onto the Stack, therefore 
microinstruction 10 gets re-executed 13 times — for a total of 14 executions 

After the Address register has decremented 13 times to 0, the RFCT instruction code causes the 2910 to output the 
next sequential instruction — that of microinstruction 1 1 . This is the terminating microinstruction for the twos com- 
plement binary division microprogram subroutine Therefore a Return-from-Subroutine code. CRTN, is transmit ted to 
the 2910 via 10-13. In order to force a pass condition, this being a Conditional Subroutine Return instruction, code CCEN 
IS output high. 
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THE 2930 AND 2932 PROGRAM CONTROL UNITS 

These two parts were designed to provide assembly language instructions with their memory address genera- 
tion logic. The internal architecture of these two devices approximates a 2901 whose local RAM has been con- 
verted into a Stack, while the Q register functions as a local data register. 

In reality, the 2930 series devices are hybrid parts that may substitute for 2909/10/11 Microprogram Sequen- 
cers, or they may be used separately to implement assembly language instructions' memory addressing logic. 
The 2930 series devices are probably more effective as microprogram sequencers. In this role you need only make 
sure that timing requirements of the 2930 series devices are compatible with the 2901 or 2903 central logic you are 
using. But as assembly language memory address generators 2930 series devices leave a great deal to be desired. They 
cannot cope with indirect memory addressing, since by its very definition indirect memory addressing requires inter- 
mediate access of external memory. Also, most minicomputer and microcomputer assembly languages depend on an 
external memory stack which cannot be implemented within the small, local stack provided by 2930 series devices. 
Therefore, 2930 series devices do little more than add indexes to base addresses. But the value of 2930 series devices 
increases dramatically when you are not building a general purpose central processing unit. If you are building dedi- 
cated CPU-based logic that uses both microcode and higher level instructions, then you can probably avoid indirect ad- 
dressing, and you can work with the limited 2930 series stack. 

The 2930 series devices are both 4-bit slices. The 2930 is the most advanced of the two devices: it is fully 
cascadable and packaged as a 28-pin DIP. The 2932 device is packaged as a 20-pin DIP and is also cascadable. 

These two devices differ only in their internal instruction logic. 

Both 2930 devices are manufactured using bipolar technology; they use a single -I-5V power supply and have TTL-level 
compatible signals. 

2930/32 DEVICE PINS AND SIGNALS 

We will describe pins and signal assignments for these two devices together, and in conjunction with their 
functional logic. Device pins and signals are illustrated in Figure 8-40. Functional logic is illustrated in Figure 
8-41. 

The Adder is central to 2930 series operations. The Adder accepts one or two operands as inputs, and generates a 
single output. The Adder can perform three different operations: 

1) It can add (with carry) the two operand inputs. CN determines the level of the carry during addition. 

2) It can increment a single operand by adding CN to the operand. 

3) It can output a single operand unaltered. 



R and S in Figure 8-41 are the two Adder operands. The R operand can have one of three 2930 SERIES 
sources. The S operand can have one of four sources. An instruction code selects the source for INSTRUCTION 
the R and S operands, together with Adder operations. The 2930 has a 5-bit instruction code, CODES 
input at 10-14. The 2932 has a 4-bit instruction code, input at 10-13. These instruction codes do 
more than control logic around the Adder and its inputs, they also control the Stack Accumulator and Program 
Counter, as summarized in Table 8-14. This table is keyed to the 2930. The set of 2932 instruction codes is a subset 
of the 2930 instruction code set, and is so identified. 

The 2930 allows you to enable or disable the Adder output using the output enable signal OE. The 2932 has no 

such output enable signal; Adder output from this device is always enabled. But when OE is input high to the 2930 the 
Y0-Y3 outputs are floated. 

Data may be held in three different places within 2930 series devices; these three places are the Accumulator, the Pro- 
gram Counter, and the Stack. 



The Accumulator is a single 4-bit location that can receive data input via D0-D3, or it can 2930 SERIES 
receive output from the Adder. The instruction code determines which of the two inputs, if ACCUMULATOR 

either, will be written into the Accumulator. The 2930, but not the 2932, has a separate Ac- 

cumulator enable control signal RE. This enable control signal is subordinate to the instruction code. The level of RE is 
unimportant when the instruction code specifies that data will be written into the Accumulator. For other instruction 
codes, a low RE input causes immediate data at D0-D3 to be written into the Accumulator. 
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2930 




(+5V) 



lO- 

FULL- 
CI- 
C(l+4)- 
CN- 
YO- 
Y1. 
Y2" 
Y3- 
GND- 



2932 




Pin Name 


Description 


Type 


D0-D3 


Data input 


Input 


YO- Y3 


Address output 


Output 


RE 


Register input enable 


Input 


OE 


Address output enable 


Input 


10 - 14/10 - 13 


Instruction input 


Input 


lEN 


Instruction enable 


Input 


CC 


Instruction condition code 


Input 


CI 


Program Counter carry in 


Input 


CO +4) 


Program Counter carry out 


Output 


CN 


Adder carry in 


Input 


C(N+4) 


Adder carry out 


Output 


G 


Adder carry generate 


Output 


P 


Adder carry propagate 


Output 


FULL 


Stack full indicator 


Output 


EMPTY 


Stack empty indicator 


Output 


CP 


Device clock 


Input 


Vcc. GND 


Power, Ground 





Figure 8-40. 2930/32 Program Control Units Signals and Pin Assignments 
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<z 



Accumulator 



V V V 

R 
3-IN MUX 



V V 



il 



4-IN MUX 



iZ 



C 



iZ 



R S 

Adder 



YO - Y3 



These signals are present in the 2930, 
but not the 2932. 
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Bit 
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Incrementer 
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.C(l+4) 



Instruction 
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II 

■12 
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•14 
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■CC 



Figure 8-41. Functional Logic for 2930 Series Progrann Control Units 
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Table 8-14. 2930 Series Program Control Unit Instruction Codes Summary 





Instruction 






Accumulator 




293214) 








Code 


Output 


New PC 


Contents 


Stack 


Instructions 


Comment 








at YO - Y3 


Contents 


(1) 


Operation 








No. 


14 13 12 11 10 


No. 


13 12 11 10 













CI 


(DI 


-(SPl 








Device reset 




1 


1 


[PCI 


[PCI + CI 


[Dl 


None 


4 


10 


Output Program Counter contents 




2 


10 


[Rl 


IPCl + CI 


[Dl 


None 


8 


10 


Output Accumulator contents 




3 


11 


[Dl 


[PCI + CI 


(DI 


None 






Output immediate data 




4 


10 


IRl + (DI + CN 


(PCI + CI 


(DI 


None 






Output sum of Accumulator contents and 
immediate data 


s 


5 


10 1 


[PC] + [Dl + CN 


[PCI + CI 


(01 


None 






Output sum of Program Counter and 


o 


















immediate data 


1 


6 


110 


[PCI +IR1+CN 


(PCI + CI 


(Dl 


None 


9 


1 0.,0 1 


Output sum of Program Counter and 


















Accumulator 


8 


7 


111 


[SI + (Dl + CN 


[PCI + CI 


(Dl 


None 






Output sum of Stack and immediate data 


1 


8 


10 


[PCI 


[PCI + CI 


[PCI* 


None 


A 


10 10 


Output Program Counter contents and 


















unconditionally load Accumulator 


1 


9 


1 1 


[Rl + [Dl + CN 


[PCI + CI 


(Rl + [Dl + CN' 


None 






Output sum of Accumulator and immediate 


















data, and unconditionally load Accumulator 




A 


10 10 


[PCI 


[PCI + CI 


(or 


None 


F 


1111 


Output Program Counter contents. Uncondition- 


3 


















ally load immediate data into Accumulator 




B 


10 11 


(PCI 


(PCI + CI 


[Dl 


PUSH (PCI 


6 


110 


Output and push Program Counter contents 




C 


110 


(PCI 


(PCI + CI 


[Dl 


PUSH [01 


2 


10 


Output Program Counter contents and push 
immediate data 




D 


110 1 


[SI 


[PCI + CI 


[Dl 


POP 






Pop and output Stack 




E 


1110 


(PCI 


[PC! + CI 


[DI 


POP 


3 


11 


Output Program Counter and pop Stack 




F 


1111 


(PC! 


[PCI 


(DI 


None 






Output and hold Program Counter 




10 


10 


(Rl 


(R + CI 


(Dl 


None 


B 


10 11 


Jump to address in Accumulator 




11 


10 1 


(Dl 


[Dl + CI 


(DI 


None 


5 


10 1 


Jump to address given by immediate data 




12 


10 10 





CI 


(Dl 


None 






Jump to "0" 




13 


10 11 


[R] + [Dl + CN 


[Rl + [Dl 
+ CN + CI 


(Dl 


None 






Jump to address given by sum of Accumulator 
and immeidate data 




14 


10 10 


[PCI + [Dl + CN 


(PCI + (D) 


(Dl 


None 






Jump to address given by sum of Program Counter 


n 








+ CN + CI 










contents and immediate data 


1 


15 


10 10 1 


[PCI + [Rl + CN 


[PCI + [Rl 


(Dl 


None 


C 


110 


Jump to address given by sum of Program Counter 








+ CN + CI 












1 


16 


10 110 


[Rl 


(Rl + CI 


(DI 


PUSH (PCI 


D 


110 1 


Jump to subroutine addressed by Accumulator 


17 


10 111 


[Dl 


(Dl + CI 


IDI 


PUSH [PCI 






Jump to subroutine addiassed by immediate data 


18 


110 





CI 


(Dl 


PUSH [PCI 






Jump to subroutine origined at 


1 


19 


110 1 


[Rl + [Dl + CN 


[Rl + IDI 


(DI 


PUSH [PCI 






Jump to subroutine addressed by sum of 








+ CN + CI 










Accumulator contents and immediate data 


r 
1 


1A 


110 10 


[PCI + (Dl + CN 


[PCI + (Dl 


(DI 


PUSH [PCI 






Jump to subroutine addressed by sum of 








+ CN + CI 










Program Counter and immediate data 


u 


18 


110 11 


[PCI + [Rl + CN 


(PCI + IRl 
+ CN + CI 


(01 


PUSH (PCI 


E 


1110 


Jump to subroutine addressed by sum of 
Program Counter and Accumulator contents 




1C 


1110 


(sr 


(SI + CI 


(Dl 


POP 


7 


111 


Return from subroutine 




1D 


1110 1 


(SI + (Dl + CN 


(SI + (DI 
+ CN + CI 


(Dl 


None 






Return from subroutine to return address 
plus immediate data 




IE 


11110 


[PCI 


(PCI 


(Dl 


None 






Output and hold Program Counter 




IF 


11111 


Off 12) 


(PCI 


(Dl 


None 


1 


1 


High impedance output. Hold Program Counter 


^^)^^ 
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ked • load the Accun 
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2930 SERrES 

PROGRAM 

COUNTER 



2930 SERIES 
STACK, PUSH, 
POP 



The Program Counter normally receives the Adder output as its new input. The Adder output 

may or may not be Incremented, depending on the level of the CI input. When the Adder is 

not outputting the prior Program Counter contents, loading this different output into the Program 

Counter constitutes a program jump. Many instruction codes bypass this jump logic by recycling 

the Program Counter contents back through the incrementer while some other output is generated by the Adder. For 

example, one instruction code causes the Adder to output data input at D0-D3. But the Program Counter contents are 

held unaltered, or incremented, depending on the level of the CI input. 

Both 2930 series devices have a 17-level Stack. Program Counter contents or data input at 
D0-D3 can be pushed onto the Stack. The 2930 series push operation is a little unusual. The 

Stack Pointer is incremented, then the selected data is written into the newly addressed Stack 

location. Thus, following a push, the Stack Pointer addresses the data most recently pushed onto 

the Stack. It is more traditional for the Stack Pointer to address the first free Stack location. When you pop a 2930 

series Stack, you decrement the Stack Pointer contents, and that is all. Thus, in order to read data off the top of 

the Stack, you select an instruction code which reads data from the Stack, then you pop the Stack. The more traditional 
Stack architecture requires that you pop the Stack, then read data from the top of the Stack. 

The 2930 series Stack Pointer is not wrap-around. If the number of pushes exceeds the 
number of pops by more than seventeen, the Stack Pointer continues to address the topmost 
Stack location. If you attempt to pop the Stack when the Stack Pointer is addressing location 0, 
then it continues to address location 0. 

When the Stack Pointer is addressing either of the two top Stack locations, the FULL signal is output low. When you 
execute a push while the Stack Pointer is addressing the top Stack location, data is written into this top location, over- 
writing whatever was there before. 



2930 SERIES 
STACK POINTER 



2930 SERIES 
CARRY LOGIC 



The 2930, but not the 2932, has a Stack Empty indicator. This signal, EMPTY, is output low following a reset, or after 
the lowest level Stack location has been popped. 

2930 series devices are cascadable. However, the 2930 has more cascading logic than the 2932. Unlike the 2901 and 
the 2903, the 2930 series devices do not have Shifters along data paths, therefore the Accumulator, Stack, and Pro- 
gram Counter do not need parallel interconnect signals. Parallel interconnect signals are needed only to cascade the 
Program Counter as it increments, or the Adder following an increment or addition. For the Program Counter there is a 
carry input, CI, and a carry output, C(l-l-4), The delay between CI being input and C(l-l-4) being output is very short. 
There is plenty of time for this ripple carry to propagate through four slices, for a 1 6-bit address, within one microcycle. 
For timing details see the data sheets at the end of this chapter. 

Both 2930 series Adders have a carry input, CN, and a carry output, C(N+4). Only the 2930 
has P and S* outputs, the carry propagate and generate. Therefore only the 2930 allows you to 
use a 2902 carry look-ahead generator. When using the 2932 device, you must rely on ripple car- 
ry. For a discussion of carry look-ahead and ripple carry, refer to the 2901 and 2902 device descriptions given earlier in 
this chapter. 

USING 2930 SERIES DEVICES 

You must be careful when deciding how to use 2930 device read/write locations. You should not use these loca- 
tions to implement CPU registers if you are designing any type of general purpose minicomputer or microcomputer. 
That is because you will have to perform a sequence of pushes and pops, each requiring a single microcycle, in order to 
select an arbitrary location. Moreover, every time you perform a push in order to increment the address, you will 
simultaneously write into the newly addressed location — something you may not wish to do. Thus the Stack lets you 
have 17 levels of subroutine within the program logic that you use to generate addresses. 

You can use the 2930 series Accumulator to implement a CPU register. For example, 
many primitive Central Processing Units have a single Index register whose contents can con- 
tribute to address generation logic, but not to CPU arithmetic or logic operations. The 2930 
series Accumulator would be an ideal location for such an Index register. 

If you are designing a special purpose Central Processing Unit using 2930 series devices, you may well be able to use 
the 17-level Stack to give you all the CPU registers you require. Knowing in advance the limitations of 2930 series 
Stack access, you can design your microprogram around these limitations so that addresses are stored in the proper 
serial sequence within the 2930 series Stack. 



2930 SERIES 
INDEX REGISTER 
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DATA SHEETS 

This section contains specific electrical and tinning data for the following devices: 

. Am2901. Am2901A. and Am2901B 

• Am2902A Carry Look-Ahead Generator 

• Am2903 Enhanced Microprocessor Slice 

• Am2910, Ann2909, and Am2911 Microprogrann Sequencers 

• Am2930 Program Control Unit 
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Figure 2. ALU Source Operand Control. 



Figure 3. ALU Function ControL 
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Figure 4. ALU Destination Control. 
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Figure 5. Source Operand and ALU Function Matrix. 

Data sheets on pages 8-D2 through 8-D25 Copyright ® 1978 by Advanced Micro Devices, Inc. Reproduced with permission of 
copyright owner. 
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Am290 1/2901 A 

SOURCE OPERANDS AND ALU FUNCTIONS 



There are eight source operand pairs available to the ALU as 
selected by the Iq, h, and I2 instruction inputs. The ALU can 
perform eight functions; five logic and three arithmetic. The 
I3, I4. and I5 instruction input* control this function selection. 
The carry input. Op, also affects the ALU results when in the 
arithmetic mode. The On input has no effect in the logic mode. 
When \q through 1 5 and On are viewed together, the matrix of 



Figure 5 results. This matrix fully defines the ALU/source 
operand function for each state. 

The ALU functions can also be examined on a "task" basis, 
i.e., add, subtract, AND, OR, etc. In the arithmetic mode, the 
carry will affect the function performed while in the logic 
mode, the carry will have no bearing on the ALU output. 
Figure 6 defines the various logic operations that the Am2901 A 
can perform and Figure 7 shows the arithmetic functions of 
the device. Both carry-in LOW (On = 0) and carry-in HIGH 
(Op = 1 ) are defined in these operations. 























Octal 
'543. '210 


Group 


Function 






40 




AAQ 




4 1 
4 5 


AND 


AAB 
DAA 








46 




DAQ 






30 




AVQ 




3 1 


OR 


AVB 








3 5 


DVA 








3 6 




DVQ 






6 




AVQ 




6 1 
6 5 
6 6 


EX-OR 


AVB 
DVA 
DVQ 












Octal 
'543. '210 


Cn = (Low) 


Cn = 1 (High) 




Group 


Function 


Group 


Function 


7 




AVQ 







A+Q 




A-^Q-H 




7 5 


EX-NOR 


DVA 




1 


ADD 


A+B 


ADD plus 


A+B+1 






76 




DVQ 




5 
6 




D-l-A 
D-HQ 


one 


D+A-H 
D+Q+1 




7 2 
7 3 
7 4 


INVERT 


Q 
B 
A 


2 
3 


PASS 


Q 
B 


Increment 


Q+1 

B-H 




7 7 




D 




4 
7 




A 
D 




A+1 
D+1 




6 2 
6 3 
64 
6 7 


PASS 


Q 
B 


1 2 
1 3 


Decrement 


Q-1 
B-1 


PASS 


Q 
B 






D 




1 4 

2 7 




A-1 
D-1 




A 
D 




3 2 




Q 


2 2 




-Q-1 




-Q 




34 
3 7 


PASS 


A 
D 




2 3 
2 4 
1 7 


1's Comp. 


-B-1 
-A-1 
-D-1 


2's Comp. 
(Negate) 


-B 
-A 
-D 




4 2 







1 




Q-A-1 




Q-A 




4 3 
4 4 
4 7 


"ZERO- 









1 1 


Subtract 


B-A-1 


Subtract 


B-A 










1 5 


(1's Comp) 


A-D-1 


(2's Comp) 


A-D 












1 6 

2 
2 1 
2 5 




O-D-l 
A-O-l 
A-B-1 
D-A-1 




Q-D 
A-Q 
A-B 
D-A 




50 
5 1 
5 5 


MASK 


AAQ 
AAB 
DAA 




56 




DAQ 




2 6 




D-Q-1 




D-Q 




F 


igure 6. ALU Logic Mode Functions 


• 


Figu 


re 7. ALU Arithmetic Mode Functions. 
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Am2901 



MAXIMUM RATINGS (Above which the useful life may be impaired) 



Storage Temperature 


-65°Cto+150°C 


Temperature (Ambient) Under Bias 


-55°Cto+125°C 


Supply Voltage to Ground Potential 


-0.5 V to +6.3 V 


DC Voltage Applied to Outputs for HIGH Output State 


-0.5 V to +Vgc max. 


DC Input Voltage 


-0.5 V to +5.5 V 


DC Output Current, Into Outputs 


30 mA 


DC Input Current 


-30 mA to +5.0 mA 



P/N 



OPERATING RANGE 
Ambient Temperature 



Vcc 



Am2901PC, DC 


0°C to +70°C 


4.75 V to 5.25 V 


Am2901DM,FM 


-55°Cto+125°C 


4.50 V to 5.50 V 



STANDARD SCREENING 

(Conforms to Ml L-STD-883 for Class C Parts) 



Step 


Ml L-STD-883 
Method 


Conditions 


Level 1 


Am2901PC,DC 


Ain2901DM, FM 


Pre-Seal Visual Inspection 


2010 


B 


100% 


100% 


Stabilization Bake 


1008 


24-hour 
^ 150°C 


100% 


100% 


Temperature Cycle 


1010 


J, -65°Cto+150°C 
10 cycles 


100% 


100% 


Centrifuge 


2001 


B 10,000 G 


100% * 


100% 


Fine Leak 


1014 


A 5x 10-8 atm-cc/cm3 


100% • 


100% 


Gross Leak 


1014 


C2 Fluorocarbon 


100% * 


100% 


Electrical Test 

Subgroups 1 and 7 


5004 


See below for 
definitions of subgroups 


100% 


100% 


Insert Additional Screening here for Class B Parts | 


Group A Sample Tests 
Subgroup 1 
Subgroup 2 
Subgroup 3 
Subgroup 7 
Subgroup 8 
Subgroup 9 


5005 


See below for 
definitions of subgroups 


LTPD = 5 
LTPD = 7 
LTPD = 7 
LTPD = 7 
LTPD = 7 
LTPD = 7 


LTPD = 5 
LTPD = 7 
LTPD = 7 
LTPD = 7 
LTPD = 7 
LTPD = 7 



'Not applicable for Am2901PC 



ADDITIONAL SCREENING FOR CLASS B PARTS 



Step 


Ml L-STD-883 
Method 


Conditions 


Level 


Am2901DMB.FMB 


Burn-In 


1015 


n 125°C 
160 hours min. 


100% 


Electrical Test 
Subgroup 1 
Subgroup 2 
Subgroup 3 
Subgroup 7 
Subgroup 9 


5004 




100% 
100% 
100% 
100% 
100% 


Return to Group A Tests in Standard Screening 



ORDERING INFORMATION 



Package 
Type 



Temperature 
Range 



Order 
Number 



Molded DIP 

Hermetic DIP 

Hermetic DIP 

Hermetic Flat Pack 

Dice 



C to +70 C 

0°C to +70°C 

-55°Cto+125°C 

-55°Cto+125°C 

0°C to +70° C 



AM2901PC 
AM 290 IDC 
AM2901DM 
AM2901FM 
AM2901XC 



GROUP A SUBGROUPS 

(as defined in Ml L-STD-883, method 5005) 



Subgroup 


Parameter 


Temperature 


1 


DC 


25°C 


2 


DC 


Maximum rated temperature 


3 


DC 


Minimum rated temperature 


7 


Function 


25°C 


8 


Function 


Maximum and minimum rated 
temperature 


9 


Switching 


25°C 


10 


Switching 


Maximum Rated Temeperature 


11 


Switching 


Minimum Rated Temperature 
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Am2901 

ELECTRICAL CHARACTERISTICS OVER OPERATING RANGE (Unless Otherwise Noted) 
(Group A, Subgroups 1, 2 and 3) 



Parameters 


Description 


Test Conditions (Note 1 ) 




Min. 


Typ. 

(Note 2) 


Max. 


Units 


VOH 


Output HIGH Voltage 


Vcc - MIN. 
V|N = V|H0rV|L 


IqH ° -1.6mA 
Yo,Yi,Y2,Y3 


2.4 






Volts 


IOH--10mA, Cn+4 


2.4 






l0H = -800mA, OVR,? 


2.4 






iQH - -600m A, F3 


2.4 






lOH = -600mA 
RAMq, 3, Qq, 3 


2.4 






IOH = -1-6mA,G 


2.4 






'CEX 


Output Leakage Current 
for F = Output 


Vcc - MIN., Vqh - 5.5V 
V|N-V|HOrV|L 






250 


mA 


Vol 


Output LOW Voltage 


Vcc -MIN., 
V|N = V|HOrV|L 


IOL''6mA 
Yo,Yi,Y2,Y3,g 






0.5 


Volts 


iQL-IOmA.Cn+A, F=0 






0.5 


l0L = 8.0mA, OVR,P 






0.5 


Iql "6.0mA, F3 
RAMo,3.Qo,3 






0.5 


V|H 


Input HIGH Level 


Guaranteed input logical HIGH 
voltage for all inputs 


2.0 






Volts 


V|L 


Input LOW Level 


Guaranteed input logical LOW 
voltage for all inputs 


Military 






0.7 


Volts 


Commercial 






0.8 


V| 


Input Clamp Voltage 


Vcc = MIN., liN = -18mA 






-1.5 


Volts 


l|L 


Input LOW Current 


Vcc = MAX. 
V|N = 0.5V 


Clock, OE 






-0.36 


mA 


Aq, Ai , A2, A3 






-0.36 


80,81,82,83 






-0.36 


Do. Di,D2, D3 






-0.72 


10.'l.l2."l6.l8 






-0.36 


I3. I4. I5. I7 






-0.72 


RAMo, 3. Qq, 3 <No« 4) 






-0.8 


Cn 






-3.6 


l|H 


Input HIGH Current 


Vcc = MAX. 
V|N = 2.7V 


Clock, OE 






20 


mA 


Ao,Ai,A2, A3 






20 


80,81,82,83 






20 


Do. D1.D2. D3 






40 


I0.ll.l2. l6. l8 






20 


I3.'4.l5.l7 






40 


RAMo, 3, Qo, 3 (Note 41 






100 


Cn 






200 


h 


Input HIGH Current 


Vcc = MAX., V||M = 5.5V 






1.0 


mA 


'OZH 
'OZL 


Off State (High Impedance) 
Output Current 


Vcc = MAX. 


Yo,Yi, 
Y2.Y3 


Vo = 2.4V 






50 


mA 


Vo - 0.5V 






-50 


RAMo 3. 
00,3' 


Vo = 2.4V 

(Note 41 






100 


Vo - 0.5V 
(Note 4) 






-800 


'OS 


Output Short Circuit Current 
(Note 3) 


Vcc = 5.75V 
Vo - 0.5V 


Yo,Yi,Y2,Y3,G 


-15 




-40 


mA 


Cn+4 


-15 




-40 


OVR,P 


-15 




-40 


F3 


-15 




-40 


RAMo, 3. Qq, 3 


-15 




-40 


Ice 


Power Supply Current 


Vcc = MAX. 


Military 




185 


280 


rtiA 


Commercial 




185 


280 



For conditions shown as MIN. or MAX., use the appropriate value specified under Electrrcal Characteristics for the applicable device type. 

Typical limits are at Vqq = 5.0V, 25°C ambient and maximum loading. 

Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second. 

These are three-state outputs internally connected to TTL inputs. Input characteristics are measured with Ig7g in a state such that the 

three-state output is OFF. 
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Am2901 

GUARANTEED OPERATING CONDITIONS 
OVER TEMPERATURE AND VOLTAGE 

Tables I, 11, and III below define the timing requirements of 
the Am2901 In a system. The Am2901 is guaranteed to 
function correctly over the operating range when used within 
the delay and set-up time constraints of these tables for the 
appropriate device type. The tables are divided into three 
tyr)es of parameters; clock characteristics, combinational delays 
from inputs to outputs, and set-up and hold time requirements. 
The latter table defines the time prior to the end of the cycle 
(i.e., clock LOW-to-HIGH transition) that each Input must be 
stable to guarantee that the correct data is written Into one of 
the internal registers. 

The performance of the Am2901 within the limits of these 
tables is guaranteed by the testing defined as "Group A, 
Subgroup 9" Electrical Testing. For a copy of the tests and 
limits used for subgroup 9, contact Advanced Micro Devices' 
Product Marketing. 



TABLE I 



CYCLE TIME AND CLOCK CHARACTERISTICS 



TIME 


Am2901DC,PC 


Am2901DM,FM 


Read-Modlfy-Write Cycle 
(time from selection of 
A, B registers to end of 
cycle) 


105 ns 


120 ns 


Maximum Clock Frequency to 
Shift Q Register (50% duty 
cycle) 


9.5MHz 


8.3 MHz 


Minimum Clock LOW Time 


30ns 


30 ns 


Minimum Clock HIGH Time 


30 ns 


30 ns 


Minimum Clock Period 


105 ns 


120 ns 



TABLE II 
MAXIMUM COMBINATIONAL PROPAGATION DELAYS (all In ns, Cl < 15pF) 





Am2901DC, PC (0°C to +70°C; 5V ±5%) 


Am2901DM, FM (-55°C to -H25°C; 5 V ±10%) | 


^^\ To 
_ ^\ Output 
From \. 

Input ^\^ 


Y 


FS 


Cn+4 


G,P 


F=0 

Rl= 

470 


OVR 


Shift 
Outputs 


Y 


FS 


On+A 


G,P 


F=0 

rl= 

470 


OVR 


Shift 
Outputs 


RAMq 

RAM3 


Qo 
Q3 


RAMo 
RAM3 


Qo 
03 


A, B 


110 


85 


80 


80 


110 


75 


110 


- 


120 


95 


90 


90 


120 


85 


120 


- 


D (arithmetic mode) 


100 


70 


70 


70 


100 


60 


95 


- 


110 


80 


75 


75 


110 


65 


105 


- 


D(l = X37)(Note5) 


60 


50 


- 


- 


60 


- 


60 


- 


65 


55 


- 


- 


65 


- 


65 


- 


Cn 


55 


35 


30 


- 


50 


40 


55 


- 


60 


40 


30 


- 


55 


45 


60 


- 


l012 


85 


65 


65 


65 


80 


65 


80 


- 


90 


70 


70 


70 


85 


70 


85 


- 


<345 


70 


55 


60 


60 


70 


60 


65 


- 


75 


60 


65 


65 


75 


65 


70 


- 


1678 


55 


- 


- 


- 


- 


- 


45 


45 


60 


- 


- 


- 


- 


- 


50 


50 


OE Enable/Disable 


40/25 


- 


- 


- 


- 


- 


- 


- 


40/25 


- 


- 


- 


- 


- 


- 


- 


A bypassing 
ALU (1 = 2xx) 


60 


- 


- 


- 


- 


- 


- 


- 


65 


- 


- 




- 


- 


- 


- 


ClockJT (Note6) 


115 


85 


100 


100 


110 


95 


105 


60 


125 


95 


110 


110 


120 


105 


115 


65 



SET-UP AND HOLD TIMES (all 


n ns) (Note 1 ) 


TABLE III 






From Input 


Notes 


Am2901DC,PC (0°C to +70°C, 5V ±5%) 


Am2901 DM, FM (-55°C to +1 25°C, 5V ±1 0%) | 


Set-Up Time 


Hold Time 


Set-Up Time 


Hold Time 


A, B 
Source 


2,4 
3,5 


105 
tpwL + 30 





120 
tpwL + 30 





B Dest. 


2,4 


tpwL+ 15 





tpwL-H5 





D (arithmetic mode) 




100 





110 





D(l = X37)(Note5) 




60 





65 





Cn 




55 





60 





'012 




85 





90 





'345 




70 





75 





'678 


4 


tpwL+ 15 





tpwL + 15 





RAMo, 3. Qo, 3 




30 





30 






NotM:1. Sn Figure 11 and 12. 

2. If th« B addrats is uiad a> a source operand, allow for the "A, B source" set-up time; if it is used only for the destination address, use the 
"B dest." set-up time. 

3. Where two numbers are shown, both must be met. 

4. "tpvy,L" is the clock LOW time. 

5. DVO is the fastest way to load the RAM from the O inputs. This function is obtained with I = 337. 

6. Using Q register as source operand in arithmetic mode. Clock is not no.rmally in critical speed path when Q is not a source. 
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ELECTRICAL CHARACTERISTICS OVER OPERATING RANGE (Unless Otherwise Noted) 
(Group A, Subgroups 1 , 2, and 3) Data in bold face is changed from Am2901 

Typ. 
Parameters Description Test Conditions (Note 1) Min. (Note 2) 


Max. 


Units 






VOH 


Output HIGH Voltage 


Vcc = MIN. 
V|N'V|HOrV|u 


lOH = -1.6mA 
Yo.Vi,Y2,Y3 


2.4 






Volts 




lOH = -1.0mA,Cn+4 


2.4 






lOH =-800^A,OVR,P 


2.4 






IQH = -600M. F3 


2.4 






lOH = -600mA 
RAMO, 3, Qq, 3 


2.4 






IOH=-1-6mA,G 


2.4 






'CEX 


Output Leakage Current 
for F » Output 


Vcc = MIN., VoH = 5-5V 
V|N = V|H0rV|L 






250 


^A 


Vol 


Output LOW Voltage 


Vcc = MIN., 
V|N = V|H 
orViL 


Y0.Y1.Y2,Y3 


Iql - iOniA (COM'L) 






0.5 


Volts 


l0L= 16mA (MIL) 






0.5 


G,F = 


Iql -16mA 






0.5 


Cn-f4 


Iql - 10mA 






0.5 


OVR,P 


Iql = 8.0mA 






0.5 


F3, RAMo, 3_ 

Qo,3 


IQU = 6.0mA 






0.5 


V|H 


Input HIGH Level 


Guaranteed input logical HIGH 
voltage for all inputs (Note 7) 


2.0 






Volts 


V|L 


Input LOW Level 


Guaranteed input logical LOW 
voltage for all inputs (Note 7} 






0.8 


Volts 


V| 


Input Clamp Voltage 


Vcc = MIN., I|N = -18mA 






-1.5 


Volts 


l|L 


Input LOW Current 


Vcc = MAX., V|N =0.5V 


Clock, OE 






-0.36 


mA 


Aq. Ai, A2, A3 






-0.36 


Bo, Bi, 62,83 






-0.36 


Dq, Di,D2, D3 






-0.72 


io.i1.i2.i6. la 






-0.36 


I3, I4. I5. I7 






-0.72 


RAMq, 3. Qo, 3 (Note 4) 






-0.8 


Cn 






-3.6 


■iH 


Input HIGH Current 


Vcc = MAX., V|N = 2.7V 


Clock, OE 






20 


jiA 


Aq, Ai, A2, A3 






20 


80,81,82,83 






20 


Do, Di,D2, D3 






40 


Iq. H. 12. '6. la 






20 


I3. I4. I5. I7 






40 


RAMo, 3, Qo, 3lNote4) 






100 


Cn 






200 


"1 


Input HIGH Current 


Vcc = MAX., V|N = 5.5V 






1.0 


mA 


lOZH 
'OZL 


Off State (High Impedance) 
Output Current 


Vcc = MAX. 


Yo.Yl. 
Y2.Y3 


Vo = 2.4V 






SO 


mA 


Vq = 0.5V 






-50 


RAMq 3 
Q0.3 


Vq = 2.4V 
(Note 41 






100 


Vq = 0.5V 
(Note 4) 






-800 


'OS 


Output Short Circuit Current 
(Note 3) 


Vcc = S.75V,Vo = 0.5V 


Yo.Yi,Y2,Y3,G 


-30 




-85 


mA 


Cn+A 


-30 




-85 


OVR, P 


-30 




-85 


F3 


-30 




-85 


RAMq, 3, Qq, 3 


-30 




-85 


'cc 


Power Supply Current 
(Note 6) 






Ta = 25° C 




160 


250 


mA 


Vcc = MAX. 
(See graph) 


Am2901APC, DC 


Ta = 0°Cto-l-70°C 




160 


265 


Ta = +70°C 




160 


220 


Am2901ADM,FM 


Tc = -55°Cto 
+125°C 




160 


280 


Tc = +125°C 




160 


190 




Notes: 1. For conditions shown as MIN. or IVIAX., use the appropriate value specified under Electr 

2. Typical limits are at V^c = 5.0V, 25°C ambient and maximum loading. 

3. Not more than one output should be shorted at a time. Duration of the short circuit test sh 

4. These are three-state outputs internally connected to TTL inputs. Input characteristics are 
state output is OFF. 

5. "MIL" = Am2901AXM, DM, FM. "COM'L" = Am2901AXC, PC, DC. 

6. Worst case \qq is at minimum temperature. 

7. These input levels provide zero noise immunity and should only be tested in a static, noise- 


cal Characte 

ould not exc 
neasured wit 


istics for 

Bed one se 
h Ig7g in 


he applicabi 

cond. 

J state such t 


B device type 
hat the three 
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SWITCHING CHARACTERISTICS 
OVER OPERATING RANGE 

Tables IV, V, and VI below define the timing characteristics of 
the Am2901 A at 25°C over the operating voltage and tempera- 
ture range. The tables are divided into three types of para- 
meters; clock characteristics, combinational delays from inputs 
to outputs, and set-up and hold time requirements. The later 
table defines the time prior to the end of the cycle (I.e., clock 
LOW-to-HIGH transition) that each Input must be stable to 
guarantee that the correct data is written Into one of the 
Internal registers. 

Measurements are made at 1.5V with V|L = OVand V||-| = 3.0V. 
For three-state disable tests, C|_ = 5.0pF and measurement is 
to 0.5V change on output voltage level. 



TABLE IV 
CYCLE TIME AND CLOCK CHARACTERISTICS 



Commercial = 


Am2901APC, DC, XC 




0°C to -^70°C 




4.75 to 5.25V 


Military = 


Am2901ADIVI, FM, XM 




-55°Cto-H25°C 




4.50 to 5.50V 



TIME 


COMMERCIAL 


MILITARY 


Read-Modify-Write Cycle 
(time from selection of 
A, B registers to end of 
cycle) 


100 


110 


Maximum Clock Frequency to 
Shift Q Register {50% duty 
cycle) 1 = 432 or 632 


15MHz 


12MHz 


Minimum Clock LOW Time 


30ns 


30ns 


Minimum Clock HIGH Time 


30ns 


30ns 


Minimum Clock Period 


100ns 


110ns 



TABLE V 
COMBINATIONAL PROPAGATION DELAYS (all In ns, Cl = 50pF (except output disable tests)) 





COMMERCIAL 


MILITARY 1 


^\ To 
Input ^\^ 


Y 


F3 


Cn-h4 


G,P 


F = 

rl= 

470 


OVR 


Shift 
Outputs 


Y 


F3 


Cn-1-4 


G,.P 


F=0 

rl= 

470 


OVR 


Shift 
Outputs 


RAMq 
RAM3 


Qo 
Q3 


RAMq 
RAM3 


Qo 
Q3 


A, B 


80 


80 


75 


65 


90 


85 


95 


- 


85 


85 


80 


70 


100 


90 


100 


- 


D (arithmetic mode) 


45 


45 


45 


35 


60 


55 


65 


- 


50 


50 


50 


40 


65 


60 


70 


- 


D(l = X37)(Note5) 


40 


40 


- 


- 


55 


- 


60 


- 


45 


45 


- 


- 


60 


- 


65 


- 


Cn 


30 


30 


20 


- 


50 


30 


50 


- 


35 


35 


25 




55 


35 


55 


- 


'012 


55 


55 


50 


45 


70 


65 


75 


- 


60 


60 


55 


50 


75 


70 


80 


- 


'345 


55 


55 


55 


50 


70 


65 


75 


- 


60 


60 


60 


55 


75 


70 


80 


- 


'678 


30 


- 


- 


- 


- 


- 


30 


30 


35 


- 




- 


- 


- 


35 


35 


OE Enable/Disable 


35/25 


- 


- 


- 




- 


- 


- 


40/25 


- 


- 


- 


- 


- 


- 


- 


A bypassing 
ALU (1 = 2xx) 


45 


- 


- 


- 




- 


- 


- 


50 




- 


- 


- 


- 


- 


- 


Clock _f~ (Note 6) 


60 


60 


60 


50 


75 


70 


80 


30 


65 


65 


65 


55 


85 


75 


85 


35 



SET-UP AND HOLD TIMES (all 


n ns) (Note 1) 


TABLE VI 






From Input 


Notes 


COMMERCIAL 


MILITARY 1 


Set-Up Time 


Hold Time 


Set-Up Time 


Hold Time 


A, B 
Source 


2,4 

3,5 


100 
tpv„L+30 





110 

tpwL+30 





B Dest. 


2,4 


tpwL+15 





tpwL+15 





D (arithmetic mode) 




70 





75 





D(l = X37)(Note5) 




60 





65 





Cn 




55 





60 





'012 




80 





85 





'345 




80 





85 





'678 


4 


tpwL+30 





tp^L-^30 





RAMq, 3, Go, 3 




25 





25 






Notes: 1. See Figure 11. 

2. If the B address is used as a source operand, allow for the "A, 8 source" set-up time; if it is used only for the destination address, use the 
"B Dest" set-up time. 

3. Where two numbers are shown, both must be met. 

4. "tpvyL" is the clock LOW time. 

5. D V is the fastest way to load the RAM from the D inputs. This function is obtained with I = 337. 

6. Using Q register as source operand in arithmetic mode. Clock is not normally in critical speed path when Q is not a source. 
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SET-UP AND HOLD TIMES (minimum cycles from each input) time prior to the clock until the hold time after the clock. The 

set-up times allow sufficient time to perform the correct 
Set-up and hold times are defined relative to the clock LOW-to- operation on the correct data so that the correct ALU data 
HIGH edge. Inputs must be steady at all times from the set-up can be written into one of the registers. 



mmwm 



lYiViViYiViYiViYiYiViYm' 



is 



3ffl 



3ffi 



immmmimmmmmim. 



i 



Figure 11. Minimum Cycle Times from Inputs. Numbers Shown are Minimum Data 

Stable Times for Am2901ADC, in ns. See Table III for Detailed Information. 
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Figure 12. 
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PRELIMINARY DATA 

ELECTRICAL CHARACTERISTICS OVER OPERATING RANGE (Unless Otherwise Noted) 

IGroup A, Subgroups 1, 2, and 3) 

Typ 
Parameters Description Test Conditions (Note 1) Min (Note 21 Max 


Units 






VOH 


Output HIGH Voltage 


Vcc=MIN. 
V|N=V|HOrV|L 


Iqh = -1.6mA 
Yo.Yi,Y2,Y3 


2.4 






Volts 




IOH = -10rnA, Cn+4 


2.4 






IQH = -800)iA, OVR, P 


2.4 






IQH = -600»iA, F3 


2.4 






lOH = -SOOjiA 
RAMq, 3, Qq, 3 


2.4 






Iqh = -1.6mA, G 


2.4 






ICEX 


Output Leakage Current 
for F = Output 


Vcc = MIN., V(3H= 5.5V 
V|N-V|HOrV|L 






250 


mA 


Vol 


Output LOW Voltage 


Vcc = MIN., 
V|N = V|H 
orViL 


Y0.Yl.Y2,Y3 


Iqi_ - 20mA (COM-L) 






0.5 


Volts 


l0L= 16mA (MIL) 






0.5 


^, F = 


Iql = 16mA 






0.5 


Cn+4 


l0L= lOmA 






0.5 


OVR, P 


Iql = 8.0mA 






0.5 


F3, RAMq, 3, 

Qo,3 


Iql ° 6.0mA 






0.5 


V|H 


Input HIGH Level 


Guaranteed input logical HIGH 
voltage for all inputs (Note 7) 


2.0 






Volts 


V|L 


Input LOW Level 


Guaranteed input logical LOW 
voltage for all inputs (Note 7) 






0.8 


Volts 


Vi 


Input Clamp Voltage 


Vcc = MIN., I|N= -18mA 






-1.5 


Volts 


'IL 


Input LOW Current 


Vcc = MAX., V|N= 0.5V 


Clock, OE 






-0.36 


mA 


Aq, Ai, A2, A3 






-0.36 


Bo, Bi, 82, 83 






-0.36 


Do, Di, D2, D3 






-0.72 


I0.ll.l2.l6.l8 






-0.36 


I3. I4.I5. I7 






-0.72 


RAMq, 3, do, 3 (Note 4) 






-0.8 


Cn 






-3.6 


l|H 


Input HIGH Current 


Vcc = MAX., V|N = 2.7V 


Clock, OE 






20 


mA 


Aq. Ai, A2, A3 






20 


80.61,82,83 






20 


Do, D,, D2, D3 






40 


I0.h.l2. l6. Is 






20 


I3. I4. I5.I7 






40 


RAMq, 3, Qq, 3lNote4) 






100 


Cn 






200 


•l 


Input HIGH Current 


Vcc = MAX., V|N = 5.5V 






1.0 


mA 


lOZH 
'OZL 


Off State (High Impedance) 
Output Current 


Vcc = MAX. 


Y0.Y1, 
Y2.Y3 


Vq = 2.4V 






50 


mA 


Vq = 0.5V 






-50 


RAMo 3 

Qo,3 


Vq = 2.4V 
(Note 4) 






100 


Vq = 0.5V 
(Note 4) 






-800 


'OS 


Output Short Circuit Current 
(Note 3) 


Vcc = MAX. + 0.5V, Vq = 0.5V 


Yo.Yl,Y2,Y3,G 


-30 




-85 


mA 


Cn+4 


-30 




-85 


OVR,P 


-30 




-85 


F3 


-30 




-85 


RAMq, 3, Go, 3 


-30 




-85 


"CC 


Power Supply Current 
(Note 61 






Ta = 25°C 




160 


250 


mA 


Am2901BPC, DC 


TA = 0°Cto+70°C 






265 


Vcc'MAX. 

(See Fig. 12) 


Ta = +70°C 






220 


Am2901BDM. FM 


Tc=-55°Cto 
+ 125°C 






265 


Tc = +125°C 






198 




Notes: 1. For conditions shown as MIN 

2. Typical limits are at Vqc = 5° 

3. Not more than one output sho 

4. These are three-state outputs ir 
state output is OFF. 

5. "MIL" = Am2901BXM, DM, F 

6. Worst case ]qq is at minimum 

7. These input levels provide zero 


or MAX., use the appropriate value specified under Electr 
V, 25''C ambient and maximum loading. 

jid be shorted at a time. Duration of the short circuit test sh 
ternally connected to TTL inputs. Input characteristics are 

M. "COM'L = Am2901BXC,-PC, DC 
emperature. 
noise immunity and should only be tested in a static, noise- 


cal Characteristics for the applicab 

ould not exceed one second, 
measured with Igys in a state such 

free environment. 


e device typ 
hat the thre 
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I. Typical Room Temperature Performance 

The tables betow specify the typical performance of the Am2901 B 
at 25°C and 5.0V. All data are in ns, with inputs changing between 
OV and 3V at 1 V/ns and measurements made at 1 .5V. For 
guaranteed data, see following pages. 



A. Cycle Time and Clock Characteristics. 



Read-Modify-Write Cycle (from selection of A, B registers 
to end of cycle.) 


45ns 


Maximum Clock Frequency to shift Q (SO*^ duty cycle, 
1 = 432 or 632) 


33MHz 


Minimum Clock LOW Time 


30ns 


Minimum Clock HIGH Time 


30ns 


Minimum Clock Period 


60ns 



B. Combinational Propagation Delays. 
Cl = 50pF 



— _Io^u^ut 
From Input 


Y 


F3 


Cn+4 


G,P 


F=0 


OVR 


RAMO 
RAMS 


QO 
Q3 


A, B Address 


38 


41 


39 


33 


44 


44 


50 


- 


D 


22 


23 


24 


20 


28 


29 


31 


- 


Cn 


17 


19 


13 


- 


22 


19 


26 


- 


1012 


30 


30 


29 


27 


34 


34 


38 


- 


1345 


32 


32 


30 


25 


32 


30 


34 


- 


1678 


17 


- 


- 


- 


- 


- 


16 


16 


A Bypass ALU 
(1 = 2XX) 


22 


- 


- 


- 


~ 


- 


- 


- 


Clock _f~ 


29 


31 


29 


23 


33 


35 


40 


19 



C. Set-up and Hold Times Relative to Clock (CP) Input. 



Input 




r 


^ 




CP: 

Set-up Ti 
Before H 


me 


L 

Hold Time 
After L -^ H 


Hold Time 
After H -> L 


Set-up Tim 
Before L -* 


e 


A, B Source Address 


8 


(Note 3) 


45 (Note 4) 





B Destination 
Address 


4 


Do Not 


Change 





D 


- 


- 


35 





Cn 


- 


- 


26 





1012 


- 


- 


37 





1345 


- 


- 


38 





1678 





Do Not Change 





RAMO, 3, QO, 3 


~ 


- 


9 






D. Output Enable/Disable Times. 
Output disable tests performed with C|. = 5pF and 
measured to 0.5V change of output voltage level. 



Input 


Output 


Enable 


Disable 


OE 


Y 


12 


27 



Notes: 1. A dash indicates a propagation delay path or set-up time constraint does not exist. 

2. Certain signals must \» stable during the entire clock LOW time to avoid erroneous operation. This is indicated by the phrase "do not change". 

3. Source addresses must be stable prior to the clock H ->- L transition to allow time to access the source data before the latches close. The A 
address may then l)e changed. The B address could be changed if it is not a destination; i.e. if data Is not being written back into the RAM. Normally 
A and B ara not changed during the clock LOW time. 

4. The set-up time prior to the clock L -> H transition is to allow time for data to be accessed, passed through the ALU, and returned to the RAM. It 
includes all the time from stable A and 8 addresses to the clock L ->^ H transition, regardless of when the clock H ->- L transition occurs. 
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I. Guaranteed Commercial 
Range Performance 

The tables below specify the guaranteed performance of the 
Am2901 B over the commercial operating range of 0°C to + 70°C, 
with Vcc from 4.75V to 5.25V. All data are in ns, with inputs 
switching between OV and 3V at 1 V/ns and measurements made 
at 1 .5V. All outputs have maximum DC load. 

This data applies to the following part numbers: Am2901BPC 

Am2901BDC 



A. Cycle Time and Clock Characteristics. 



Read-Modify-Write Cyde (from selection of A, B registers 
to end of cyde.) 


69ns 


Maximum Clock Frequency to shift Q (SOC? duty cycle, 
1 = 432 or 632) 


16MHz 


Minimum Clock LOW Time 


30ns 


Minimum Clock HIGH Time 


30ns 


Minimum Clock Period 


69ns 



B. Combinational Propagation Delays. 
Cl = 50pF 



— __ToOutput 
From Input 


Y 


F3 


Cn+4 


G, P" 


F=0 


OVR 


RAMO 
RAMS 


QO 
Q3 


A, B Address 


6C 


61 


59 


50 


70 


67 


71 


- 


D 


38 


36 


40 


33 


48 


44 


45 


- 


Cn 


30 


29 


23 


- 


37 


29 


38 


- 


1012 


50 


47 


45 


45 


56 


53 


57 


- 


1345 


49 


48 


44 


45 


54 


49 


53 


- 


1678 


28 


- 


- 


- 


- 


- 


27 


27 


A Bypass ALU 
(1 = 2XX) 


37 


- 




- 


- 


- 




- 


Clock _f~ ^ 


49 


48 


. 47 


37 


58 


55 


59 


29 



C. Set-up and Hold Times Relative to Clock (CP) Input. 



Input 




T 


7 




CP: 

Set-up Time 
Before H -» L 


L 

Hold Time 
After L-»- H 


Hold Time 
After H -» L 


Set-up Time 
Before L -»^ H 


A, B Source Address 


20 


(Note 3) 


69 (Note 4) 





B Destination 
Address 


9 


Do Not 


Change 





D 


- 


- 


51 





Cn 


- 


- 


39 





1012 


- 


- 


56 





1345 


- 


- 


55 





1678 


11 


Do Not Change 





RAMO, 3, QO, 3 




16 






D. Output Enable/Disable Times. 

Output disable tests performed with Cl = 5pF and 
measured to 0.5V change of output voltage level. 



Input 


Output 


Enable 


Disable 


OE 


y 


35 


25 



Notes: 1 . A dash indicates a propagation delay path or set-up time constraint does not exist. 

2. Certain signals must be stable during the entire clock LOW time to avoid erroneous operation. This is indicated by the phrase "do not change" 

3. Source addresses must be stable prior to the clock H ->- L transition to allow time to access the source data before the latches ctose. The A 
address may then be changed. The B address could be changed if it is not a destination; i.e. if data is not being written back into the RAM. Normally 
A and B are not changed during the clock LOW time. 

4. The set-up time prior to the ilock L ->- H transition is to allow time for data to be accessed, passed through the ALU, and returned to the FMM. It 
includes all the time from stable A and B addresses to the clock L-> H transition, regardless of when the clock H -»' L transitton occurs. 
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II. Am2901B Guaranteed Military 
Range Performance 

The tables below specify the guaranteed performance of the 
Am2901 B over the military operating range of -55°C to + 1 25°C, 
with Vcc from 4.5V to 5.5V. All data are in ns, with inputs switch- 
ing between OV and 3V at 1 V/ns and measurements made at 
1.5V. All outputs have maximum DC load. 

This data applies to the following part numbers: Am2901BDM 

Am2901BFM 



A. Cycle Time and Clock Characteristics. 



Read-Modify-Wrlte Cycle (from selection of A, B registers 
to end of cycle. 


88ns 


Maximum Clock Frequency to shift Q (50'"'f duty cycle, 
1 = 432 or 632) 


15MHz 


Minimum Clock LOW Time 


30ns 


Minimum Clock HIGH Time 


30ns 


Minimum Clock Period 


88ns 



B. Combinational Propagation Delays. 
Cl = SOpF 



— JTo^utput 
From Input 


Y 


F3 


Cn+4 


G, P^ 


F=0 


OVR 


RAMO 
RAMS 


QO 
Q3 


A, B Address 


82 


84 


80 


70 


90 


86 


94 


- 


D 


44 


38 


40 


34 


50 


45 


48 


- 


Cn 


34 


32 


24 


- 


38 


31 


39 


- 


1012 


53 


50 


47 


46 


59 


55 


58 


- 


1345 


53 


50 


46 


45 


58 


50 


55 


- 


1678 


29 


- 


- 


- 


- 


- 


27 


27 


A Bypass ALU 
(1 = 2XX) 


50 


- 


- 


- 


- 




- 


- 


Clock _^ 


53 


50 


49 


41 


63 


58 


61 


31 



C. ^t-up and Hold Times Relative to Clock (CP) Input. 



Input 




r 


1 




N 
CP: 

Set-up Time 
Before H -*^ L 


Hold Time 
After L -► H 


Hold Time 
Atter H ^ L 


Set-up Time 
Before L ^ H 


A, B Source Address 


20 


(Note 3) 


88 (Note 4) 





B Destination 
Address 


9 


Do Not 


Change 





D 


- 


- 


55 





Cn 


- 


- 


42 





1012 


- 


- 


58 





1345 


- 


- 


58 





1678 


14 


Do Not Change 





RAIVIO, 3, QO, 3 


- 


- 


18 


3 



D. Output Enable/Disable Times. 

Output disable tests performed with Cl = 5pF and 
measured to 0.5V change of output voltage level. 



Input 


Output 


Enable 


Disable 


51 


Y 


40 


35 



Notes: 1 . A dash indicates a propagation delay path or set-up tirrie constraint does not exist. 

2. Certain signals must be stable during the entire clock LOW time to avoid erroneous operation. This is indicated by the phrase "do not change". 

3. Source addresses must t)e stable prior to the clock H ->- L transition to allow time to access the source data tiefore the latches ctose. The A 
address may then tie changed. The B address could tie changed if it is not a destination; i.e. if data is not t)eing written back into the RAM. Normally 
A and B are not changed during the clock LOW time. 

4. The set-up time prior to the clock L -^ H transition Is to allow time for data to \» accessed, passed through the ALU, and returned to the RAM. It 
includes all the time from stable A and B addresses to the clock L-> H transition, regardless of when the clock H-> L transition occurs. 
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MAXIMUM RATINGS (Above which the useful life may be impaired) 



Storage Temperature 


-65°Cto+150°C 


Temperature (Ambient) Under Bias 


-55°Cto+125°C 


Supply Voltage to Ground Potential 


-0.5V to +7.0V 


DC Voltage Applied to Outputs for HIGH Output State 


-0.5V to +Vcc max. 


DC Input Voltage 


-0.5V to +5.5V 


DC Output Current, Into Outputs 


30 mA 


DC Input Current 


-30 mA to +5.0 mA 



ELECTRICAL CHARACTERISTICS OVER OPERATING TEMPERATURE RANGE (Unless Otherwise Noted) 



Am2902AXC T/^ = C to +70 C 
Am2902AXM T^ = -S5°C to +125°C 

Parameters Description 



Vcc = 5.0V ±5% (COM'L) MIN. = 4.75V 

Vcc= 5-OV ±10% (MIL) MIN. = 4.50V 

Test Conditions (Note 1 ) 



MAX. = 5.25V 
MAX. = S.50V 



Typ. 

Min. (Note 2) 



Max. 



Units 



VOH 


Output HIGH Voltage 


Vcc = MIN., IQH =-1mA 




MIL 


2.5 


3.4 




Volts 


V|N = V|Hoi-V|L 


COM 


2.7 


3.4 


Vol 


Output LOW Voltage 


Vcc = MIN., loL = 20mA 
V|N = V|HOrV|L 






0.5 


Volts 


VlH 


Input HIGH Level 


Guaranteed input logical HIGH 
voltage for all inputs 


2.0 






Volts 


V|L 


Input LOW Level 


Guaranteed input logical LOW 
voltage for ail inputs 






0.8 


Volts 


V| 


Input Clamp Voltage 


Vcc = MIN- l|N=-18mA 






-1.2 


Volts 


•iL 


Input LOW Current 


Vcc = MAX., V|N= 0.5V 


Cn 






-2 


mA 


P3 






-4 


P2 






-6 


P0.P1.G3 






-8 


Go,G2 






-14 


Gl 






-16 


•iH 


Input HIGH Current 


Vcc = MAX., V|N = 2.7V 


Cn 






50 


mA 


P3 






100 


P2 






150 


Pq, P1.G3 






200 


Gq, G2 






350 


Gl 






400 


l| 


Input HIGH Current 


Vcc = MAX., V||>j = 5.5V 






1.0 


mA 


'sc 


Output Short Circuit 
(Note 3) 


Vcc = MAX., VouT = O.OV 


-40 




-100 


mA 


Ice 


Power Supply Current 


Vcc = MAX. 
All Outputs LOW 


MIL 




69 


99 


mA 


COM'L 




69 


109 


Vcc = MAX. 
All Ouputs HIGH 


MIL 




35 




mA 


COM'L 




35 





Notes: 1. For conditions sliown as MIN. or MAX., use the appropriate value specified under Electrical Characteristics for the applicable device type. 

2. Typical limits are at Vcc " 5.0V, 25°C ambient and maximum loading. 

3. Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second. 

SWITCHING CHARACTERISTICS 

(Ta = +25°C, Vcc = 50V) 



Parameters 


Description 


Min. 


Typ. 


Max. 


Units 


Test Conditions 


*PLH 


Gj/Pi ^ Cn+j 




4.5 


7 


ns 


Cl = 15pF 
Rl = 280n 


*PHL 




4.5 


7 


*PLH 


Gj/Pi ^ G 




5 


7.5 


ns 


•PHL 




7 


10.5 


'PLH 


Pi^P 




4.5 


6.5 


ns 


IPHL 




6.5 


10 


tpLH 


Cn -* Cn+j 




6.5 


10 


ns 


*PHL 




7 


10.5 
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Am2903 
OPERATING RANGE 



P/N 


Range 


Temperature 




Vcc 




Am2903PC, DC 


COML 


Ta = 0°C to +70°C 


Vcc= 5.0V ±5% 


(MIN. = 4.75V, MAX. 


= 5.25V) 


Am2903DM, FM 


MIL 


Tc = -55°Cto +125°C 


Vcc = 5.0V ±109? 


(MIN. = 4.50V, MAX. 


= 5.50V) 



DC CHARACTERISTICS OVER OPERATING RANGE 

Parameters Description Test Conditions (Note i) 



Typ. 

(Note 2) 



Max. 



Units 



VoH 


Output HIGH Voltage 






Iqh = -1.6mA 
Y0-Y3. G/N 


2.4 






Volts 


Vcc = MIN. 


Iqh = -SOOftA 
DB0.3. P/OVR 
SlOo, SIO3, QlOo, QIO3, 
WRITE, Cn+4 


2.4 






ICEX 


Output Leakage Current 
for Z Output (Note 4) 


Vcc = MIN., VoH = 5.5V 
V|N = V|HOrV|L 






250 


mA 


Vol 


Output LOW/ Voltage 


Vcc = MIN. 

V|N = V|H=OrV|L 


Yo. Yi, Y2 
Y3.Z 


I(5l = 20mA (COML) 






0.5 


Volts 


Iql = 16mA (MIL) 


DBq, DBi, 
DBj, DB3 


Iql = 12mA (COML) 






0.5 


Iql = 8.0mA (MIL) 


G/N 


Iql = 18mA 






0.5 


P/OVR 


Iql = 10mA 






0.5 


Cn+4, SlOo 
SIO3, QlOo 
QIO3, WRITE 


Iql = 8.0mA 






0.5 


V|H 


Input HIGH Level 


Guaranteed input logical HIGH 
voltage for all Inputs (Note 6) 


2.0 






Volts 


V|L 


Input LOW Level 


Guaranteed Input logical LOW 
voltage for all inputs (Note 6) 






0.8 


Volts 


Vi 


Input Clamp Voltage 


Vcc = MIN., I|N = -18mA 






-1.5 


Volts 


l|L 


Input LOW Current 


Vcc = MAX., V|N = 0.5V 
(Note 4) 


Cn 






2.50 


mA 


Yo. Yi, Y2, Y3 






1.08 


lo. ll. I2. I3. 

I4, DAo, DAi, 
DA2, DA3, SlOo 
SIO3, QlOo, QIO3, 
MSS, DBo, DBi, 
DB2, DB3 






0.72 


All other inputs 






0.36 


l|H 


Input HIGH Current 


Vcc = MAX., V|N = 2.7V 
(Note 4) 


Cn 






120 


mA 


Yo. Yi. Y2, Y3 






110 


I0-I4, DA0-DA3 






40 


SlOo, SIO3, QlOo, 
QIO3, DB0.3. 
MSS 






90 


All other inputs 






20 


ll 


Input HIGH Current 


Vcc = MAX., V|N = 5.5V 






1.0 


mA 


Iqzh 

'OZL 


Off State 

(HIGH Impedance) 

Output Current 


Vcc = MAX., 
(Note 4) 


Y0Y3 


Vq = 2.4V 






110 


mA 


Vq = 0.5V 






-1130 


DBo_3, QIOq, QIOq, 

SIOq, SIO3, MSS/IS 


Vq = 2.4V . 






90 


Vq = 0.5V 






-770 


'OS 


Output Short Circuit 
Current (Note 3) 


Vcc = MAX + 0.5V 
Vo = 0.5V 


-30 




-85 


mA 


'cc 


Power Supply Current 
(Note 5) 


Vcc = MAX. 


Ta = 25°C 




220 


335 


mA 


COML 


Ta = to 70°C 






350 


Ta = 70°C 






291 




Tc = -55to125°C 






395 






Tc = 125°C 






258 



For conditions shown as MIN. or MAX.. use the appropriate value specified under Electrical Characteristics for the applicable device type. 

Typical limits are at Vqq = 5.0V. 25°C ambient and maximum loading. 

Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second. 

Yo-3. DBo-3, SIO0.3. QlOo, 3 and WRITE/MSS are three state outputs internally connected to TTL inputs. Z is an open -collector output internally 

connected to a TTL input. Input characteristics are measured under conditions such that the outputs are in the OFF state. 

Worst case Ice '^ ^^ minimum teh^perature. 

These input levels provide zero noise immunity and should only be tested in a static, noise-free environment. 
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SWITCHING CHARACTERISTICS (Typical Room Temperature Performance) 



Tables I, II, and III define tfie nominal timing characteristics of 
the Am2903 at 25°C and 5.0V. The Tables divide the 
parameters into three types: pulse characteristics for the clock 
and write enable, combinational delays from input to output, 
and set-up and hold times relative to the clock and write 
pulse. 

Measurements are made at 1.5V with V|l = OV and V|h = 
3.0V. For three-state disable tests, Cl = 5.0pF and mea- 
surement is to 0.5V change on output voltage level. 



TABLE I 
Write Pulse and Cloclc Characteristics 



Time 




Minimum Time CP and WE both LOW 
to write 


30ns 


Minimum Clock LOW Time 


30ns 


Minimum Clock HIGH Time 


50ns 



TABLE II 

Combinational Propagation Delays, All in ns. 

Outputs Fully Loaded. CL = 50pf (except output disable tests) 



~~~~~~~~-___To Output 
From lnpur~~~~------,.,_^ 


Y 


Cn+4 


G, P 


Z 


N 


OVR 


DB 




QlOo, QIO3 


SlOo 


SIO3 


SIO3 
(Parity) 


WRITE 


A, B Addresses 
(Arith. Mode) 


65 


60 


55 


75 


64 


70 


33 


- 


- 


61 


69 


87 


A, B Addresses 
(Logic Mode) 


56 




46 


67 


56 


- 


33 


- 


- 


55 


64 


81 


DA, DB Inputs 
(Logic Mode) 


39 


- 


25 


48 


38 


- 


- 


- 


- 


36 


47 


56 


DA, DB Inputs 
(Arlth. Mode) 


39 


37 


26 


52 


38 


51 


- 


- 


- 


36 


47 


60 


EA 


44 


38 


29 


54 


44 


53 


- 


- 


- 


42 


52 




c„ 


25 


21 


- 


39 


20 


38 


- 


- 


- 


21 


25 


48 


lo 


39 


35 


24 


48 


37 


48 


- 


•15 


- 


41 


46 




'4321 


45 


43 


32 


55 


44 


55 


- 


•17 


- 


45 


51 




18765 


25 


- 


- 


37 


- 


- 


- 


18 


22 


24 


27 




'^ 


- 


- 


- 


- 


- 


- 


- 


10 


- 


- 


- 


- 


OEB Enable/Disable 


- 




- 


- 


- 




7 


- 


- 


- 


- 


- 


OEY Enable/Disable 


10 


- 


- 


- 


- 


- 


- 


- 


- 


- 


- 


- 


SlOo, SIO3 


13 


- 


- 


- 


- 


- 


- 


- 


- 


- 


12 


18 


Clock 


58 


52 


40 


72 


56 


72 


24 


- 


28 


55 


63 


76 



•Applies only when leaving special functions. 



TABLE III 

Set-Up and Hold Times (All in ns) 

CAUTION: READ NOTES TO TABLE III. 

NA = Not Applicable; no, timing constraint. 



Input 


With Respect to 
to this Signal 


HIGH-t( 


^LOW 


LOW-to 


hHIGH 


Comment 


Set-up 


>l 


r 

Hold 




Hold 


Set-up 


Y 


Clock 


NA 


NA 


10 





To store Y in RAM or Q 


WE HIGH 


Clock 


5 


Note 2 


Note 2 





To Prevent Writing 


WE LOW 


Clock 


NA 


NA 


30 





To Write into RAM 


A,B as Sources 


Clock 


20 





NA 


NA 


See Note 3 


B as a Destination 


Clock andWE both LOW 





Note 4 


Note 4 





To Write Data only into 
the Correct B Address 


QlOo, QIO3 


Clock 


NA 


NA 


10 





To Shift Q 


18765 


Clock 


30 


Note 5 


Notes 







Ten HIGH 


Clock 


10 


Note 2 


Note 2 





To Prevent Writing 


lEN LOW 


Clock 


NA 


NA 


10 





To Write into Q 
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MAXIMUM RATINGS (Above which the useful life may be impaired) 



Storage Temperature 



Temperature (Ambient) Under Bias 



-65 C to +150 C 



-55 etc +125 C 



Supply Voltage to Ground Potential 

DC Voltage Applied to Outputs for High Output State 



-0.5V to +7.0V 



-0.5 V to Vqc max. 



DC Input Voltage 



-0.5V to +5.5V 



DC Output Current, Into Outputs 



30 mA 



DC Input Current 



-30 mA to +5.0 mA 



ELECTRICAL CHARACTERISTICS The Following Conditions Apply Unless Otherwise Specified: 
COM'L TA = 0°Cto+70°C Vcc = 5.0V ±5% MIN. = 4.75V MAX. = 5.25V 

MIL Tc = -55°Cto+125°C Vcc = 5.0V±10% IVIIN. = 4.50V MAX. = 5.50V 

DC CHARACTERISTICS OVER OPERATING RANGE 

Parameters Description Test Conditions (Note i) Min. 



Typ. 

(Note 2) 



Max. Units 



VOH 


Output HIGH Voltage 


Vcc = MIN., IQH = -1.6nnA 
V|N = V|HOr VjL 


2.4 






Volts 


Vol 


Output LOW Voltage 


Vcc = MIN. 

V|N = VjHOr V|L 


Yo-11. IOL = ISmA 






0.5 


Volts 


PL, VECT, MAP, FULL, Iql = 8mA 


V|H 


Input HIGH Level (Note 4) 


Guaranteed Input Logical HIGH 
voltage for all inputs 


2.0 






Volts 


V|L 


Input LOW Level (Note 4) 


Guaranteed input logical LOW 
voltage for all inputs 






0.8 


Volts 


V| 


Input Clamp Voltage 


Vcc = MIN., I|N = -18mA 






-1.5 


Volts 


l|L 


Input LOW Current 


Vcc = MAX., V|M =0.5V 


DO-11 






-0.87 


mA 


CI.CCEN 






-0.54 


10-3, OE,RLD 






-0.72 


5^ 






-1.31 


CP 






-2.14 


l|H 


Input HIGH Current 


Vcc = MAX., V|rg = 2.7V 


Do-11 






80 


^A 


CI,CCEN 






30 


10-3, OE, RLD 






■ 40 


cc 






50 


CP 






100 


ll 


Input HIGH Current 


Vcc = MAX., V|N = 5.5V 
Vcc = MAX. 








1.0 


mA 


isc 


Output Short Circuit Current 
(Note 3) 




-30 




-85 


mA 


lOZL 


Output OFF Current 


Vcc = MAX. 
OE = 2.4V 


VouT = 0-5V 






-50 


mA 


lOZH 


VoUT = 2.4V 






50 


icc 


Power Supply Current 






Ta = 25°C 




195 


320 


mA 


Vcc = MAX 


Am2910PC, DC 


Ta = 0°C to +70°C 






344 


Ta = +70°C 






280 


Am2910DM, FM 


Tc = -55°C to 
+125°C 






340 






Tc = +125°C 






227 



t Characteristics for the applicable 



Notes: 1. For conditions shovwn as MIN. or MAX., use the appropriate value specified unc 

2. Typical limits are at V^c = 5.0V, 25°C ambient and maximum loading. 

3. Not mora than one output should be shorted at a time. Duration of the short circuit test should not exceed one second. 

4. These input levels provide no guaranteed noise immunity and should only be tested in a static-, noise-free environment. 




See Tables A for ts and th for various 
inputs. See Tables B for combinational 
delays from clock and other Inputs to 
outputs. See Figure 5 for timing of a 
typical ecu cycle. 



Figure 2. Switching Waveforms. 
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SWITCHING CHARACTERISTICS 

The tables below define the Am2910 switching characteristics. Tables A are set-up and hold times relative to the clock LOW-to-HIGH 
transition. Tables B are combinational delays. Tables C are clock requirements. All measurements are made at 1.5V with input levels 
at OV or 3V. All values are in ns. 

TYPICAL ROOM TEMPERATURE CHARACTERISTICS (Ta = 25°C, Vcc = 5.0V, Cl = 50pF) 



A. Set-up and Hold Times 



B. Combinational Delays 



C. Clock Requirements 



Input 


U 


th 


D|-»-R 


9 


3 


D|-*-PC 


34 


1 


l0-'3 


64 





cc 


46 





CCEN 


49 


u 


CI 


26 


2 


RLD 


18 


2 



Input 


y 


PL, VECT, MAP 


Full 


Do-Dii 


14 


- 


- 


I0-I3 


40 


27 


- 


CC 


21 


- 


- 


CCEN 


23 


- 


- 


CP(note) 
1 = 8,9,15 


54 


- 


29 


CP 

Ail other 1 


26 


- 


29 


OE" 




- 


- 



Minimum Clocl^ LOW Time 


30 


ns 


Minimum Clocl< HIGH Time 


30 


ns 


Minimum Clock Period, 1=8, 9, 15 




ns 


Minimum Clock Period, 1=14 




ns 



(Clock periods for other instructions are 
determined by externa! conditions.} 

Note: These instructions are conditional on the 
counter. Delays from CP to outputs will be 
longer if t he ins truction prior to the clock was 
4 or 12 or RLD was LOW. 



GUARANTEED ROOM TEMPERATURE CHARACTERISTICS (Ta = 25 C, Vcc = 5.0V, Cl = 50pF) 



A. Set-up and Hold Times 



B. Combinational Delays 



C. Clock Requirements 



Input 


ts 


th 


Di-*R 






Di->-PC 






I0-I3 






CC 






CCEN 






Cl 






RLD 







Input 


V 


PL, VECT, MAP 


wm 


D0-D11 








IO-I3 








CC 








CCEN 








CP(note) 
1 = 8,9,15 








CP 

All other 1 








OE" 









Minimum Clock LOW Time 




ns 


Minimum Clock HIGH Time 




ns 


Minimum Clock Period, 1=8,9, 15 




ns 


Minimum Clock Period, 1=14 




ns 



{Clock periods for other instructions are 
determined by external conditions.} 

Note: These instructions are conditional 0:1 
counter. Delays from CP to outputs will b'j 
longer if t he ins truction prior to the clock v 
4 or 12 or RLD was LOW. 



GUARANTEED CHARACTERISTICS OVER COMMERCIAL OPERATING RANGE 
Am2910PC, DC (Ta = 0°C ta-^70°C, Vqc = 4.75V to 5.25V, Cl = 50pF) 



A. Set-up and Hold Times 



Input 


ts 


th 


Di->R 


15 


5 


D|->PC 


58 


3 


IO-I3 


100 





CC 


80 





CCEN 


85 





Cl 


45 


5 


RLD 


35 


3 



B. Combinational Delays 



Input 


Y 


PL, VECT, MAP 


Full 


D0-D11 


25 


- 


- 


IO-I3 


65 


48 


- 


CC- 


45 


- 


- 


(SCEn 


40 


- 


- 


CP(note) 
1 = 8,9,15 


92 


- 


- 


CP 

All other 1 


65 


- 


50 


OE 




- 


- 



C. Clock Requirements 



Minimum Clock LOW Time 


50 


ns 


Minimum Clock HIGH Time 


30 


ns 


Minimum Clock Period, 1=8, 9, 15 




ns 


Minimum Clock Period, 1 = 14 




ns 



(Clock periods for other instructions are 
determined by external conditions.} 

Note: These instructions are conditional on the 
counter. Delays from CP to outputs will be 
longer if t he ins truction prior to the clock was 
4 or 12 or RLD was LOW. 



GUARANTEED CHARACTERISTICS OVER MILITARY OPERATING RANGE 
Am2910DM, FM (Tc = -55°C to -i-125°C, Vcc = 4.5V to 5.5V, Cl = 50pF) 



A. Set-up and Hold Times 



input 


ts 


th 


Di->R 






D,->-PC 






I0-I3 






CC 






CCEN 






Cl 






RLD 







B. Combinational Delays 



Input 


Y 


PL, VECT, MAP 


Full 


D0-D11 








IO-I3 








CC 








CCEN 








CP(note) 
1 = 8,9,15 








CP 

All other 1 








OE 









C. Clock Requirements 



Minimum Clock LOW Time 




ns 


Minimum Clock HIGH Time 




ns 


Minimum Clock Period, 1=8, 9, 15 




ns 


Minimum Clock Period, 1 = 14 




ns 



(Clock pgriods for other instructions are 
determined by external conditions.) 



the 



Note: These instructions are conditional 01 
counter. Delays from CP to outputs will be 
longer if t he ins truction prior to the clock was 
4 or 12 or RLD was LOW. 
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OPERATION OF THE Am2909/Am291 1 

Figure 5 lists the select codes for the multiplexer. The two 
bits applied from the microword register (and additional com- 
binational logic for branching) determine which data source 
contains the address for the next microinstruction. The 
contents of the selected source will appear on the Y outputs. 
Figure 5 also shows the truth table for the output control and 



for the control of the push/pop stack. Figure 6 shows in detail 
the effect of Sq, Si , FE and PUP on the Am2909. These four 
signals define what address appears on the Y outputs and what 
the state of all the internal registers will be following the clock 
LOW-to-HIGH edge. In this illustration, the microprogram 
counter is assumed to contain initially some word J, the ad- 
dress register some word K, and the four words in the push/ 
pop stack contain Ra through Rrf. 



Address Selection 



OCTAL 


Si So 


SOURCE FOR V OUTPUTS 


SYMBOL 



1 
2 
3 


L L 
L H 
H L 
H H 


Microprogram Counter 
Register 
Push-Pop stack 
Direct inputs 


mpc 

REG 

STKO 

Di 







Output Control 


ORi 


ZERO 


OE 


Yi 


X 


X 


H 


Z 


X 


L 


L 


L 


H 


H 


L 


H 


L 


H 


L 


Source selected by Sq Si 



2 = High Impedance 



Synchronous Stack Control 



H = High 
L = Low 
X = Don't Care 



FE PUP 


PUSH-POP STACK CHANGE 


H X 
L H 

L L 


No change 

Increment stack pointer, then 

push current PC onto STKO 

Pop stack (decrement stack pointer) 



Figure 5. 



CYCLE 


Si.So, FE, PUP 


MPC 


REG 


STKO 


STK1 


STK2 


STK3 


YOUT 


COMMENT 


PRINCIPLE 
USE 


N 
N-HI 





J 
J+1 


K 
K 


Ra 
Rb 


Rb 
Re 


Re 
Rd 


Rd 
Ra 


J 


Pop Stack 


End 
Loop 


N 
N-H 


1 


J 

J-H 


K 
K 


Ra 
J 


Rb 
Ra 


Re 
Rb 


Rd 
Re 


J 


Push fiPC 


Set-up 
Loop 


N 
N-H 


1 X 


J 

JH-I 


K 
K 


Ra 

Ra 


Rb 
Rb 


Re 
Re 


Rd 
Rd 


J 


Continue 


Continue 


N 
N-H 


1 


J 

KH-I 


K 
K 


Ra 
Rb 


Rb 
Re 


Re 
Rd 


Rd 
Ra 


K 


Pop Stack; 

Use AR for Address 


End 
Loop 


N 
N+1 


10 1 


J 

K-H 


K 
K 


Ra 
J 


Rb 
Ra 


Re 
Rb 


Rd 
Re 


K 


Push fiPC; 
.Jump to Address in AR 


JSR AR 


N 
N-H 


1 1 X 


J 

K-H 


K 
K 


Ra 
Ra 


Rb 
Rb 


Re 
Re 


Rd 
Rd 


K 


Jump to Address in AR 


JMP AR 


N 
N-HI 


10 


J 

Ra-H 


K 
K 


Ra 
Rb 


Rb 
Re 


Re 
Rd 


Rd 
Ra 


Ra 


Jump to Address in STKO; 
Pop Stack 


RTS 


N 
N-t-1 


10 1 


J 
Ra-H 


K 
K 


Ra 
J 


Rb 
Ra 


Re 
Rb 


Rd 
Re 


Ra 


Jump to Address in STKO; 
Push juPC 




N 
N-H 


1 1 X 


J 

Ra-H 


K 
K 


Ra 
Ra 


Rb 
Rb 


Re 
Re 


Rd 
Rd 


Ra 


Jump to Address in STKO 


Stack Ref 
(Loop) 


N 
N-Hl 


110 


J 
D-Hl 


K 
K 


Ra 
Rb 


Rb 
Re 


Re 
Rd 


Rd 
Ra 


D 


Pop Stack; 

Jump to Address on D 


End 
Loop 


N 
N-H 


110 1 


J 
D-H 


K 
K 


Ra 
J 


Rb 
Ra 


Re 
Rb 


Rd 
Re 


D 


Jump to Address on D; 
Push /iPC 


JSR D 


N 
N-H 


1 1 1 X 


J 

D+1 


K 
K 


Ra 
Ra 


Rb 
Rb 


Re 
Re 


Rd 
Rd 


D 


Jump to Address on D 


JMP D 



X = Don't care, 
Note: STKO is 



= LOW, 1 = HIGH, Assume Cn = HIGH 
the location addressed by the stack pointer. 



Figure 6. Output and Internal Next-Cycle Register States for Am2909/Am2911. 
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Figure 7 illustrates the execution of a subroutine using the 
Am2909. The configuration of Figure 3 is assumed. The 
instruction being executed at any given time is the one con- 
tained in the microword register (/nWR). The contents of the 
yWR also controls (indirectly, perhaps) the four signals Sq, S^, 
FE, and PUP. The starting address of the subroutine is applied 
to the D inputs of the Am 2909 at the appropriate time. 

In the columns on the left is the sequence of microinstructions 
to be executed. At address J+2, the sequence control portion 
of the microinstruction contains the comand "Jump to sub- 



routine at A". At the time Tj, this instruction is in the/nWR, 
and the Am2909 inputs are set-up to execute the jump and 
save the return address. The subroutine address A is applied to 
the D inputs from the /iWR and appears on the Y outputs. The 
first instruction of the subroutine, 1(A), is accessed and is at 
the inputs of the /iWR. On the next clock transition, l{A) is 
loaded into the /iWR for execution, and the return address 
J-i-3 is pushed onto the stack. The return instruction is exe- 
cuted at T5. Figure 8 is a similar timing chart showing one 
subroutine linking to a second, the latter consisting of only 
one microinstruction. 



CONTROL MEMORY 



Execute 
Cycle 


Microprogram 


Address 


Sequencer 
Instruction 


To 
Ti 
T2 

Te 

T7 

T3 
T4 
T5 


J-1 

J 
J+1 
J+2 
J+3 
J+4 

A 
A+1 
A+2 


JSR A 

, 1(A) 
RTS 



CONTROL MEMORY 



Execute 
Cyde 


Microprogram 


Address 


Sequencer 
Instruction 


To 
T, 
T2 
T9 

T3 
T4 
T5 
T7 
Te 

Te 


J-1 

J 
J+1 
J+2 
J+3 

A 
A+1 
A+2 
A+3 
A+4 

B 


JSR A 

JSR B 
RTS 

RTS 



Execute Cycle 


[ To 


[Ti 


[ T2 


T3 


T4 


T5 


Te 


T7 


Ts 


1 T9 


Clock 
Signals "" 






■^ 


-L 


-L 


-L 


-L 


-L 


-L 


"L 


Am2909 
Inputs 
(from 
fiWR) 


Si,So 

FE 

PUP 

D 



H 
X 
X 



H 
X 
X 


3 

L 
H 
A 




H 
X 
X 




H 
X 
X 


2 

L 
L 
X 



H 
X 
X 




H 
X 
X 






Internal 
Registers 


UPC 
STKO 
STK1 
STK2 
STK3 


J+1 


J+2 


J+3 


A+1 
J+3 


A+2 
J+3 


A+3 
J+3 


J+4 


J+5 






Am2909 
Output 


Y 


J+1 


J+2 


A 


A+1 


A+2 


J+3 


J+4 


J+5 






ROM 
Output 


(Y) 


l(J+1) 


JSR A 


1(A) 


l(A+1) 


RTS 


l(J+3) 


l(J+4) 


l(J+5) 






Contents 
of;jWR 

(Instruction 
being 

executed) 


/LiWR 


l(J) 


l(J+1) 


JSR A 


KA) 


l(A+1) 


RTS 


l(J+3) 


l(J+4) 







Figure 7. Subroutine Execution. 



On = HIGH 



Execute Cycle 


To 


LJl 


\J2 


1 ^3 


T4 


Ts 


Te 


[T7 


LJB 


1 T9 


Clock 


— 1 


— 1 


-1 


-1 


—\ 


~I 


—I 


~~1 


— 1 


"^ 


Signals ■"" 


LJ 


^ 


M 


L. 


1—1 


L. 


UJ 


*- 


LJ 


^ 


Am2909 


Si,So 








3 








3 


2 





2 





Inputs 


FE 


H 


H 


L 


H 


H 


L 


L 


H 


L 


H 


(from 


PUP 


X 


X 


H 


X 


X 


H 


L 


X 


L 


X 


MWR) 


D 


X 


X 


A 


X 


X 


B 


X 


X 


X 


X 




ILlPC 


J+1 


J+2 


J+3 


A+1 


A+2 


A+3 


B+1 


A+4 


A+5 


J+4 




STKO 


_ 


_ 


_ 


J+3 


J+3 


J+3 


A+3 


J+3 


J+3 


_ 


Internal 


STK1 














J+3 








Registers 


STK2 
STK3 


- 


- 


- 




- 


- 




- 


- 


- 


Am2909 
Output 


Y 


J+1 


J+2 


A 


A+1 


A+2 


B 


A+3 


A+4 


J+3 


J+4 


ROM 
Output 


(Y) 


l(J+1) 


JSR A 


KA) 


l(A+1) 


JSRB 


RTS 


l(A+3) 


RTS 


l(J+3) 


l(J+4) 


Contents 
























ofiiWR 
























(Instruction 


mwr 


l(J) 


l(J+1) 


JSR A 


KA) 


l(A+1) 


JSRB 


RTS 


l(A+3) 


RTS 


l(J+3) 


being 
























executed) 

























Figure 8. Two Nested Subroutines. Routine B is Only One Instruction. 
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MAXIMUM RATINGS (Above which the useful life may be impaired) 




Storage Temperature 


-65°Cto+150''C 


Temperature (Ambient) Under Bias 


-55°Cto+125°C 


Supply Voltage to Ground Potential 


-0.5 V to +7.0 V 


DC Voltage Applied to Outputs for HIGH Output State 


-0.5 V to +Vcc max. 


DC Input Voltage 


-0.5 V to +7.0 V 


DC Output Current, Into Outputs 


30 mA 


DC Input Current 


-30 mA to +5.0 mA 



OPERATING RANGE 



P/N 


Ambient Temperature 


Vcc 


Am2909/2911DC, PC 


0°Cto+70°C 


4.75 V to 5.25 V 


Am2909/2911DM, FM 


-55°Cto+125°C 


4.50 V to 5.50 V 



STANDARD SCREENING 

(Conforms to l\/IIL-STD-883 for Class C Parts) 



Step 


MIL-STD-883 
Method 


Conditions 


Leyel | 


Am2909/Am2911PC,DC 


Am2909/Am2911DM, FM 


Pre-Seal Visual Inspection 


2010 


B 


100% 


100% 


Stabilization Bake 


1008 


24-hour 
C 150°C 


100% 


100% 


Temperature Cycle 


1010 


J, -65°Cto+150°C 
1 cycles 


100% 


100% 


Centrifuge 


2001 


B 10,000 G 


100% * 


100% 


Fine Leak 


1014 


A 5 X 10-8 atmcc/sec 


100% * 


100% 


Gross Leak 


1014 


C2 Fluorocarbon 


100% * 


100% 


Electrical Test 

Subgroups 1 and 7 


5004 


See below for 
definitions of subgroups 


100% 


100% 


Insert Additional Screening here for Class B Parts 


Group A Sample Tests 
Subgroup 1 
Subgroup 2 
Subgroup 3 
Subgroup 7 
Subgroup 8 
Subgroup 9 


5005 


See below for 
definitions of subgroups 


LTPD = 5 
LTPD = 7 
LTPD = 7 
LTPD = 7 
LTPD = 7 
LTPD = 7 


LTPD = 5 
LTPD = 7 
LTPD = 7 
LTPD = 7 
LTPD = 7 
LTPD = 7 



'Not applicable for 
Am2909PC or 
Am2911PC. 



ADDITIONAL SCREENING FOR CLASS B PARTS 



Step 


MIL-STD-883 
Method 


Conditions 


Level 


Am2909/Am2911DMB, FMB 


Burn-In 


1015 


n 125°C 
160 hours min. 


100% 


Electrical Test 
Subgroup 1 
Subgroup 2 
Subgroup 3 
Subgroup 7 
Subgroup 9 


5004 




100% 
100% 
100% 
100% 
100% 


Return to Group A Tests in Standard Screening 



GROUP A SUBGROUPS 

(as defined in MIL-STD-883, method 5005) 



Subgroup 


Parameter 


Temperature 


1 


DC 


25°C 


2 


DC 


Maximum rated temperature 


3 


DC 


Minimum rated temperature 


7 


Function 


25°C 


8 


Function 


Maximum and minimum rated 
temperature 


9 


Switching 


25°C 


10 


Switching 


Maximum Rated Temeperature 


11 


Switching 


Minimum Rated Temperature 
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ELECTRICAL CHARACTERISTICS OVER OPERATING RANGE (Unless Otherwise Noted) 

Typ. 



Parameters 


Description 


Test Conditions (Note 1) 


Min. 


(Note 2) 


IVIax. 


Units 


VOH 


Output HIGH Voltage 


Vcc = MIN., 
V,N=V,HOrV|L 


MIL 


'oh = -1-0mA 


2.4 






Volts 


COM'L 


lOH = -2.6mA 


2.4 






Vol 


Output LOW Voltage 


Vcc = MIN., 
V|N = V|HOrV|L 


l0L = 4.0mA 






0.4 


Volts 


l0L = 8.0mA 






0.45 


l0L = 12mA 
(Note 5) 






0.5 


V|H 


Input HIGH Level 


Guaranteed input logical HIGH 
voltage for all inputs 


2.0 






Volts 


V|L 


Input LOW Level 


Guaranteed input logical LOW 
voltage for all inputs 


MIL 






0.7 


Volts 


COM'L 






0.8 


V| 


Input Clamp Voltage 


Vcc = MIN., l|N = -18mA 






-1.5 


Volts 


l|L 


Input LOW Curreftt 


Vcc = MAX.. 
V|N = 0.4V 


Cn 






-1.08 


mA 


Push/Pop, Of 






-0.72 


Others (Note 6) 






-0.36 


l|H 


Input HIGH Current 


Vcc = MAX., 
V|N = 2.7V 


Cn 






40 


mA 


Push/Pop 






40 


Others (Note 6) 






20 


<l 


Input HIGH Current 


Vcc = MAX., 
V|N = 7.0V 


Cn, Push/Pop 






0.2 


mA 


Others (Note 6) 






0.1 


'OS 


Output Short Circuit Current 
(Note 3) 


Vcc = MAX. 


Y0-Y3 


-30 




-100 


mA 


Cn + 4 


-30 




-85 


'cc 


Power Supply Current 


Vcc = MAX. (Note 4) 




80 


130 


mA 


'OZL 


Output OFF Current 


Vcc = MAX., 
OE = 2.7V 


VOUT = 0.4V 






-20 


mA 


'OZH 


V0UT = 2.7V 






20 



For conditions shown as MIN. or MAX., use the appropriate value specified under Electrical Characteristics for the applicable device type. 

Typical limits are at Vqq = 5.0V, 25°C ambient and maximum loading. 

Not more than one output should be shorted at a time. Duration of the short circuit test should not exceed one second. 

Apply GND to C„, Rq, R-i, R2, R3, ORq, OR^, OR2, OR3, Dg, D-i, D2, and D3. Other inputs open. All outputs open. Measured after a 

LOW-to-HIGH clock transition. 

The 12mA guarantee applies only to Yg, Y-i, Y2 and Y3. 

For the Am2911, O; and Ri are internally connected. Loading is doubled (to same values as Push/Pop). 



P (TABLE I 



7 V\\V\\\\\\\\\V / 

_(_ \\\CL0CKH TO L OCCURSy \\ _(_ 

I N\ anytime here \\|r "7 



Figure 12. Switching Waveforms. See Tables for Specific Values. 



3.0V 
1.5V 





MM 


I \ 


ffi- 




CLOCK TO Y| or C„ 1 4 




INPUTST0VorC„,.4 








(TABLE III 






(TABLE II) 
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Am2909 • Am2911 



SWITCHING CHARACTERISTICS 
OVER OPERATING RANGE 

Tables I, II, and III below define the timing characteristics of 
the Am2909 and Am2911 over the operating voltage and 
temperature range. The tables are divided into three types of 
parameters; clock characteristics, combinational delays 
from inputs to outputs, and set-up and hold time require- 
ments. The latter table defines the time prior to the end of 
the cycle (i.e., clock LOW-to-HIGH transition) that each 
input must be stable to guarantee that the correct data is 
written into one of the internal registers. 

Measurements are made at 1.5V with V|l = OV and Vjh = 
3.0V. For three-state disable tests, Cl = 5.0pF and measure- 
ment is to 0.5V change on output voltage level. 

TABLE I 
CYCLE TIME AND CLOCK CHARACTERISTICS 



TIME 


COMMERCIAL 


MILITARY 


Minimum Clock LOW Time 


30 


35 


Minimum Clock HIGH Time 


30 


35 



TABLE II 

MAXIMUM COMBINATIONAL PROPAGATION DELAYS 

(all in ns, Cl = 50pF (except output disable tests)) 



From ^^^^ 
input ^^\ 


COMMERCIAL 


MILITARY 


Y Cn+4 


Y Cn+4 


Di 


17 


30 


20 


32 


Sq, Si 


30 


48 


40 


50 


ORi 


17 


30 


20 


32 


Cn 


- 


14 


- 


16 


ZERO 


30 


48 


40 


50 


OE LOW (enable) 


25 


- 


25 


- 


OE HIGH (disable) 


25 


- 


25 


- 


Clock t SiSo = LH 


43 


55 


50 


62 


Clock t SiSo = LL 


43 


55 


50 


62 


Clock t SiSo = HL 


80 


95 


90 


102 



Operating Range 


Part Numbers 


Power Supply 


Temperature Range 


Commercial 


Am2909PC, DC 
Am2911PC, DC 


5.0V ± 5% 


Ta = 0°C to +70°C 


Military 


Am2909DM, FM 
Am2911DM 


5.0V ± 10% 


Tc = -55Xto +125°C 



TABLE ill 
GUARANTEED SET-UP AND HOLD TIMES (all in ns) (Note 1) 



From Input 


Notes 


COMMERCIAL 


MILITARY 


Set-Up Time 


Hold Time 


Set-Up Time 


Hold Time 


RE 




22 


5 


22 


5 


R| 


2 


10 


5 


12 


5 


PUSH/POP 




26 


6 


30 


7 


FE 




26 


5 


30 


5 


Cn 




28 


5 


30 


5 


D| 


2 


30 





35 


3 


OR] 




30 





35 


3 


So, Si 




45 





50 





ZERO 




45 





50 






Notes: 1. All times relative to clock LOW-to-HIGH transition. 

2. On Am2911, Rj and D,- are internally connected together and labeled Dj. Use R,- set-up and hold times when D inputs are used to load register. 



Metallization and Pad Layout 



Am2909 

:2 21 20 19 18 




Am2911 

19 18 17 16 15 14 13 12 



DIE SIZE 0.110" X 0.1 60" 
Numbers correspond to DIP pin-out 
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Am2930 



MAXIMUM RATINGS (Above which the useful life may be impaired) 



Storage Temperature 


-65 to +150°C 


Temperature (Ambient) Under Bias 


-55 to +125-0 


Supply Voltage to Ground Potential 


-0.5 to +7.0V 


DC Voltage Applied to Outputs for High Output State 


-0.5V to Vcc max. 


DC Input Voltage 


-D.5 to +5.5V 


DC Output Current, Into Outputs 


30mA 


DC Input Current 


-30 to +5.0mA 



OPERATING RANGE 

Part Number Temperature Vqq 



Am2930PC, DC 


Ta = to 70°C 


4.75V to 5.25V 


Am2930DM, FM 


Tc = -55 to +125°C 


4.50V to 5.50V 



DC CHARACTERISTICS OVER OPERATING RANGE 

Parameters Description Test Conditions (Note i) 



Typ 

Min (Note 2) Max 



Notes: 1. For conditions shown as MIN. or MAX., use the 

2. Typical limits are at V^c = 5.0V, 25°C ambient i 

3. Not more than one output should be shorted at 

4. These input levels provide no gi#aranteed noise 

5. Minimum 1^^ 's at maximum temperature. 



appropriate value specified under Electrical Characteristics for the applicable device type. 

ind maximum loading. 

a time. Duration of the short circuit test should not exceed one second. 

immunity and should only be tested in a static-, noise-free environment. 



Units 



VOH 


Output HIGH Voltage 


Vcc = MIN., 
ViN = V,LOrV|H 


Yo. Yi, Y2, Y3 

G,Cn+4. 

Ci-H4 


Iqh = -1.6mA 


2.4 






Volts 


P, FULL, 
EMPTY 


Iqh = -1.2mA 


2.4 






Vol 


Output LOW Voltage 


Vcc = MIN. 
V|N = V|LOrV|H 


Yo.Yi,Y2,Y3 


Iql = 20mA 
(COM'L) 






0.5 


Volts 


Iql = 16mA (MIL) 






0.5 


G, Cn-i-4 
Ci+4 


Iql = 16mA 






0.5 


P. FULL, 
EMPTY 


Iql = 12mA 






0.5 


V|H 


Input HIGH Level (Note 4) 




2.0 






Volts 


V|L 


Input LOW Level (Note 4) 








0.8 


Volts 


V| 


Input Clamp Voltage 


Vcc = MIN., I|N = 


-18mA 






-1.5 


Volts 


l|L 


Input LOW Current 


Vcc = MAX.,V|N 


= 0.5V 


Do-3 






-.360 


mA 


I0-4, RE, lEN, 
CP, OE 






-.702 


CC 






-.657 


Ci 






-2.31 


Cn 






-3.25 


l|H 


Input HIGH Current 


Vcc = MAX., V|N 


= 2.7V 


Do-3 






20 


^A 


I0-4, RE, lEN, 
CP, OE 






40 


CC 






50 


Ci 






90 


Cn 






250 


li 


Input HIGH Current 


Vcc = MAX.,V|N 


= 5.5V 






1.0 


mA 


isc 


Output Short Circuit Current 
(Note 3) 


Vcc = MAX. 


-30 




-85 


mA 


Iqzl 


Output OFF Current 


Vcc = MAX., OE = 


= 2,4V 


VouT = 0.5V 






-50 


fiA 


Iqzh 


VouT = 2.4V 






50 


Ice 


Power Supply Current 
(Note 5) 


Vcc = 5.0V 


Ta = 25X 




150 


205 


mA 


Vcc = MAX. 


Tc=- 
Tc = - 


-55 to -)-125°C 






239 


H25°C 






170 


Ta = to 70°C 






220 


Ta = 70X 






185 
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Am2g30 SWITCHING CHARACTERISTICS 

Tables A, B, C and D define the timing characteristics of the Am2930. Measurements are made at 1.5V with Vil 
V|H = 3.0V. For three-state disable tests, Cl = S.OpF and measurement is to 0.5V change on output voltage level. 



OV and 



TABLE lA 
Clock Characteristics. 



Minimum Clocl( LOW Time 


IBns 


Minimum CUxM HIGH Time 


20ns 



TABLE IB 
Output Enable/Disable Times. 

All in ns. 
;l = 5.0pF for output disable tests. 



From 


To 


Enable 


Disable 


OE 


Y 


18 


17 


CC 
(Note 1) 


Y 


39 


27 


U-0 
(Note 1) 


Y 


57 


41 



I. Typical Room Temperature Performance. 

Vcc = 5.0V, Ta = 25°C 

TABLE IC 
' Combinational Propagation Delays. 

All in ns. 
Outputs fully loaded. Cl = 50pF. 



\^ To 
X^utput 

Input ^^ 


Y 


G,P 


Cn+4 


Ci+4 
U = L 


Ci+4 
l4 = H 


FuiJ 




Empty 


I4-0 


61 


50 


57 


61 


69 


52 


- 


00 


46 


32 


39 


- 


53 


29 


- 


Cn 


25 




17 


- 


32 


- 


- 


C( 


- 






14 


14 


- 


- 


CP 


52 


40 


46 


33 


58 


40 


40 


D 


37 


23 


30 


- 


43 


- 


- 


lEN 


-■ 


- 


- 


- 




27 


- 



TABLE ID 
Set-up and Hold Times. All in ns. 

All relative to clock 
LOW-to-HIGH transition. 



Note 1 : "Suspend" instruction. 



Input 


CP: , 






Set-up 
Time 


Hold 
Time 


U-o 


68 





CC 


53 





ilN 


39 





Cn 


28 





Ci 


18 


3 


D (RE = L, 

I4.0 = 0-8 or 10-15) 


14 





D (All other conditions) 


44 





RE 


13 


2 



II. Guaranteed Performance Over Commercial Operating Range. 



TABLE HA 
Clock Characteristics. 



Minimum Clock tOW Time 


31ns 


Minimum Clock HIGH Time 


33ns 



TABLE IIB 
Output Enable/Disable Times. 

All in ns. 
Cl = 5.0pF for output disable tests. 



From 


To 


Enable 


Disable 


OE 


Y 


27 


26 


CC 
(Note 1) 


Y 


55 


37 


I4-0 
(Note 1) 


Y 


80 


55 



Vcc = ^^-75 to 5.25V, Ta = to 70°C 

TABLE lie 
Combinational Propagation Delays. 

All in ns. 
Outputs fully loaded. Cl = 50pF. 



V To 
X^utput 
From^^ 
Input \ 


Y 


G,P 


Cn-^4 


Ci-^4 
l4=L 


Ci-H4 
l4=H 


fSTi 




Empty 


U-o 


81 


67 


77 


80 


91 


69 


- 


CC 


63 


45 


55 


- 


72 


42 


- 


Cn 


32 


- 


25 


- 


45 


- 


- 


Ci 


- 


- 


- 


22 


22 


- 


- 


CP 


69 


53 


61 


43 


78 


55 


55 


D 


49 


33 


40 




59 


- 


- 


iEN 


- 










40 


- 



TABLE IID 
Set-up and Hold Times. All in ns. 

All relative to clock 
LOW-to-HIGH transition. 



Note 1 : "Suspend" instruction. 



Input 


CP: , 






Set-up 
Time 


Hold 
Time 


I4-0 


114 





CC 


75 





lEN 


55 





Cn 


43 





Ci 


. 32 


5 


D (RE = L. 

I4.0 = 0-8 or 10-15) 


25 


2 


D (All other conditions) 


66 


2 


RE 


24 


4 



TABLE IMA 
Clock Characteristics. 



Minimum Clock LOW Time 


35ns 


Minimum Clock HIGH Time 


35ns 



III. Guaranteed Performance Over Military Operating Range. 

Vcc = 4.5 to 5.5V, Tc = -55 to -l-125°C 

TABLE NIC 
Combinational Propagation Delays. 

All in ns. 
Outputs fully loaded. Cl = 50pF. 



TABLE IIIB 
Output Enable/Disable Times. 

All in ns. 
',1 = S.OpF for output disable tests. 



From 


To 


Enable 


Disable 


OE 


Y 


32 


31 


CC 
(Note 1) 


Y 


60 


42 


I4-0 
(Note 1) 


Y 


85 


60 



\ To 
x^utput 
FroniN. 
Input X..^ 


Y 


G,P 


Cn-^4 


Ci-H4 
l4=L 


Ci+4 
l4 = H 


fUIF 




Empty 


I4.0 


88 


74 


82 


87 


97 


78 


- 


CC 


68 


52 


60 


- 


78 


47 


- 


Cn 


37 


- 


30 


- 


46 


- 


- 


Ci 




- 




23 


23 


- 




CP 


74 


58 


66 


48 


84 


60 


60 


D 


55 


38 


45 




65 


- 




IEN 


- 


' 


- 






45 


- 



TABLE HID 
Set-up and Hold Times. All in ns. 

All relative to clock 
LOW-to-HIGH transition. 



Note 1 ; "Suspend" instruction. 



Input 


CP:, 






Set-up 
Time 


Hold 
Time 


I4-0 


124 





CC 


80 





IEN 


69. 





Cn 


52 





Ci 


37 


5 


D (RE = L, 

U.Q = 0-8 or 10-15) 


30 


2 


D (All other conditions) 


72 


2 


RE 


29 


4 
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INDEX 



CP1600 
direct addressing. 2-3 
implied addressing, 2-4 
I/O port pin characteristics, 2-30 
stack addressing, 2-5 

8086 

AX register. 5-5 

base relative, indexed addressing, 5-15 

BCD addition, 5-49 

BCD division, 5-51 

BCD multiplication, 5-51 

BCD subtraction, 5-49 

Bus Interface Unit (BlU), 5-30 

BX register, 5-5 

Code Segment register, 5-8 

Control signals, simple and complex, 5-28 

CX register, 5-5 

data memory base relative addressing, 5-16 

Data Segment register, 5-11 

Destination Index register, 5-10 

direct memory addressing, 5-13 

dual bus complexity, 5-28 

DX register. 5-5 

-8080A register compatibility. 5-5 

Execution Unit (EU). 5-30 

external memory addressing, 5-24 

Extra Segment register, 5-10 

hold, in min. and max. mode systems, 5-39 

implied memory addressing, 5-14 

indirect addressing, 5-22 

instruction queue, 5-31 

interrupt return, 5-46 

interrupt vector table, 5-44 

I/O port addressing, 5-21 

maskable interrupt, 5-44, 5-45 

non-maskable interrupt, 5-44, 5-45 

program counter, 5-8 

program relative addressing, 5-21 

reset, 5-27 

Segment registers, 5-7 

softwrare interrupts, 5-44, 5-45 

Source Index register, 5-10 

Stack Pointer register, 5-9, 5-11 

Stack Segment register, 5-9 
8212. used in INS8900 system 

as input port. 1-39. 1-40 

as output port. 1-41 
8251 USART. used in INS8900 system. 1-43 
8253 Programmable Counter/Timer. 

used in INS8900 system. 1-43 
8288 Bus Controller 

interrupt signals. 5-110 

I/O bus mode, 5-109 

memory protect. 5-109 

write control signals. 5-109 

INS8900. See also PACE/INS8900 
address/data lines, demultiplexing. 1-38 
control signal polarity considerations. 1-39 
8251 and 8253 used with. 1-43 



8255 PPI devices used with, 1-42, 1-43 
6800 support devices not compatible with, 1-44 
INS8900/PACE. See PACE/INS8900 

MC68000 

absolute data addressing, 7-30 

address registers, 7-3 

autovector interrupt response, 7-27 

bus and address error exception processing, 7-25 

data registers, 7-2 

exception priorities, 7-23 

exception vector table, 7-23 

externally generated exceptions, 7-23 

immediate data addressing, 7-37 

implied register addressing, 7-32 

internally generated exceptions, 7-22, 7-23 

interrupt request exception processing, 7-26 

memory interface, 7-9 

operating modes. 7-22 

program counter relative addressing. 7-32 

read timing. 7-13 

register direct addressing, 7-30 

register indirect address, 7-30 

reset exception processing, 7-25 

spurious interrupt, 7-27 

Stack Pointer, 7-4 

Status register, 7-5 

wait state, 7-14 

write timing. 7-14 
MicroNova I/O bus.4-12 

Nova 

addressing. 4-6-9 

address space. 4-23 

busy status. 4-21 

done status. 4-21 

registers. 4-22 
9440 

initialization. 4-16 

instruction fetch. 4-24 

I/O wait states. 4-28 

memory read. 4-24 

system bus. 4-14 

PACE. See also PACE/I NS8900 

clock signals. 1-11 

level interrupt problems. 1-24 

stack interrupt problems. 1-22 

substrate bias voltage, generating. 1-35 

TTL-level bus. 1-2 
PACE/I NS8900 

address latches and decoders. 1-2 

bidirectional transceiver element (BTE). 1-2 

BTE mode control signals. 1-37 

busses, floating, 1-15 

CONTIN signal, 1-15 

CPU-initiated DMA block data transfers, 1-16 

cycle-stealing DMA. 1-17. 1-18 

data input cycle. 1-12 

data output cycles. 1-13 

direct addressing options, 1-24 



PACE/INS8900 (Continued) 

direct indexed addressing, 1-7 

DMA block data transfers, 1-16, 1-17 

execution speed, 1-1 

Extend signal for slow I/O operations, 1-13 

Extend used to suspend I/O during DMA operations, 
1-17 

Halt state, 1-14 

interrupts, 1-21-23 

logic level, 1-2 

machine cycle, 1-12 

NHALT signal, 1-15 

power supply, 1-1 

processor stall, 1-15 

registers, saving during interrupts, 1-22 

return from interrupt, 1-21 

signal differences, 1-10 

split base page, 1-6, 1-7 

stack interrupts, 1-5 

STE clock frequency, 1-35 

system timing element (STE), 1-2 
TMS 9900 

context switch, 3-5, 3-6 

memory addresses, 3-3 

direct addressing, 3-6 

indexed addressing, 3-6 

instruction execution sequences, 3-18 

internal operations machine cycle, 3-15 

interrupt vector map, 3-27 

multiple interrupt hardware considerations, 3-30 

program memory addressing, 3-8 
TMS 9902 

break, 3-91 

break logic, 3-86 

Control register, 3-86 

device initialization, 3-84 

error flags, 3-93 

internal clock signal, 3-88 

interrupts, 3-86, 3-87 

receive logic, 3-92 

receiver status, 3-87 

register addressing, 3-84 

reset, 3-86 

Status register, 3-87 

test mode, 3-86 

timer status, 3-87 

Transmit/Receive Data Rate register, 3-88 

transmit event sequence, 3-90 

transmitter status, 3-87 
TMS 9903 

asynchronous break logic, 3-103 

asynchronous receive, 3-110 

asynchronous transmit, 3-109 

bisync logic, 3-105 

clock rate option, 3-106 

Control register, 3-100 

CRC options, 3-106 

device intialization, 3-109 

device reset, 3-100 

external sync logic, 3-104 

HDLC abort, 3-104 

initialize CRC, 3-100 

initialize transmit/receive, 3-100 

interface signal, 3-97 

interrupt enable/disable, 3-102 

modes, 3-97 

monosync logic, 3-105 

NRZI select, 3-106 

Parameter register, 3-103 



parity options, 3-105 

Read register addressing, 3-100 

receive CRC, 3-102 

received character size, 3-106 

register select, 3-100 

SDLC configurations, 3-105 

SDLC loop, 3-111 

SDLC receive logic, 3-104 

serial I/O signals, 3-98 

Status register, 3-106 

sync strip, 3-105 

test mode, 3-102 

transmit controls, 3-102 

transmit operation, 3-104 

Write register addressing, 3-101 
TMS 9940 

CPU bit utilization, 3-59 

hold logic, 3-64 

idle logic, 3-64 

expansion mode, 3-60 

multiprocessor system interface, 3-61 

simple CPU I/O mode, 3-59 

sync mode, 3-64 
TMS 9980 series clock logic, 3-49 
2901 

ALU logic, 8-13 

carry status, 8-24 

data input, 8-33 

half-carry status, 8-25 

local RAM, 8-7 

microcode, sample, 8-25 

microinstruction, 8-9 

multiply, 8-35 

overflow status, 8-24 

Q register, 8-12 

RAM and CPU registers, 8-10 

rotate operation, 8-25 

sample microcode, 8-25 

shift operation, 8-25 

sign status, 8-24 

status logic, 8-24 

zero status, 8-24 
2903 

ALU functions, 8-57 

ALU input, 8-48 

ALU input options, 8-44 

ALU operand options, 8-49 

ALU output destinations, 8-61 

ALU shifter, 8-61 

Arithmetic and Logic Unit (ALU), 8-49 

destination options, 8-59 

double length normalization, 8-67. 8-68 

increment function, 8-72 

local RAM addressing, 8-56 

normalize special functions, 8-67 

shift logic. 8-60 

sign extend logic, 8-63 

signal/magnitude twos complement function, 8-69 

single length normalization, 8-7 

slice significance select, 8-45 

status signals, 8-46 

three-address microcycle, 8-56 

two-address timing. 8-56 

twos complement divide function, 8-77 

twos complement multiply function, 8-73 

unsigned multiply, 8-72 
2909 output mask, 8-99 
2909/291 1 

Address, 8-95 



data output, 8-99 

immediate data input, 8-95 

incrementer, 8-99 

instruction skip, 8-100 

jump, 8-100 

microprogram counter, 8-99 

multiple jump, 8-103 

output select, 8-95 

output zero control, 8-99 

sequential addresses, 8-99 

single instruction reexecution, 8-100 

stack, 8-100 

subroutine call, 8-102 

subroutine nesting, 8-103 
2910 

address output, 8-110 

condition codes, 8-113 

data input, 8-110 

increment, 8-113 

instruction codes, 8-113 

microprogram counter, 8-110, 8-113 

microprogram initialization, 8-120 

microprogram jump, 8-120 

microprogram jump-to-subroutine, 8-120 

stack, 8-113 
2930 series 

accumulator, 8-125 

carry logic. 8-129 

Index register, 8-129 

instruction codes, 8-125 

Program Counter, 8-129 

Stack Pointer, 8-129 

Stack, Push, Pop. 8-129 



Z8000 
auto-increment, 6-18 
auto-decrement, 6-18 
base relative addressing, 6-15 
block transfer instructions, 6-40 
byte registers, 6-9 
conditional jump instructions, 6-40 
divide instruction, 6-38 
implied indexed addressing, 6-15 
implied memory addressing. 6-11 



indirect memory addressing. 6-18 

instruction fetch machine cycle. 6-23 

I/O instructions. 6-36 

LDPS instruction, 6-39 

Ml and MO instructions, 6-41 

memory interface logic, 6-20 

memory read machine cycle, 6-23 

memory write machine cycle, 6-23 

multiply instruction, 6-39 

New Program Status Area pointer. 6-8 

normal mode, 6-3 

primary memory reference instructions. 6-37 

principal memory addressing modes. 6-37 

Program Counter 6-6 

Refresh Counter. 6-28 

secondary memory reference instructions. 6-37 

shift instructions. 6-41 

sixteen-bit registers. 6-9 

software traps. 6-32 

Special I/O instructions. 6-37 

stack. 6-18 

stack instructions. 6-41 

Stack Pointer. 6-3 

status. 6-6 

subroutine call, 6-40 

system call, 6-40 

system mode. 6-3 

thirty-two-bit registers. 6-9 

wait state. 6-23 
Z8001 

address representation. 6-3 

base address. 6-9 

long segmented base relative addressing. 6-17 

long segmented direct memory addressing. 6-13 

long segmented indexed addressing. 6-15 

program relative addressing. 6-18 

segmented mode. 6-7 

short segmented base relative addressing. 6-16 

short segmented indexed addressing. 6-14 
Z8002 

direct memory addressing. 6-12 

indexed addressing. 6-14 

program relative addressing. 6-17 

short segmented direct memory addressing. 6-13 
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